hotspot/src/cpu/x86/vm/x86_32.ad
author thartmann
Tue, 03 Nov 2015 09:41:03 +0100
changeset 33628 09241459a8b8
parent 33465 6063f28a6efb
child 34162 16b54851eaf6
permissions -rw-r--r--
8141132: JEP 254: Compact Strings Summary: Adopt a more space-efficient internal representation for strings. Reviewed-by: alanb, bdelsart, coleenp, iklam, jiangli, jrose, kevinw, naoto, pliden, roland, smarks, twisti Contributed-by: Brent Christian <brent.christian@oracle.com>, Vivek Deshpande <vivek.r.deshpande@intel.com>, Tobias Hartmann <tobias.hartmann@oracle.com>, Charlie Hunt <charlie.hunt@oracle.com>, Vladimir Kozlov <vladimir.kozlov@oracle.com>, Roger Riggs <roger.riggs@oracle.com>, Xueming Shen <xueming.shen@oracle.com>, Aleksey Shipilev <aleksey.shipilev@oracle.com>, Sandhya Viswanathan <sandhya.viswanathan@intel.com>
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
     1
//
28954
7dda6c26cc98 8068977: Remove unused sun.misc.Unsafe prefetch intrinsic support
psandoz
parents: 27677
diff changeset
     2
// Copyright (c) 1997, 2015, Oracle and/or its affiliates. All rights reserved.
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
     3
// DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
489c9b5090e2 Initial load
duke
parents:
diff changeset
     4
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
     5
// This code is free software; you can redistribute it and/or modify it
489c9b5090e2 Initial load
duke
parents:
diff changeset
     6
// under the terms of the GNU General Public License version 2 only, as
489c9b5090e2 Initial load
duke
parents:
diff changeset
     7
// published by the Free Software Foundation.
489c9b5090e2 Initial load
duke
parents:
diff changeset
     8
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
     9
// This code is distributed in the hope that it will be useful, but WITHOUT
489c9b5090e2 Initial load
duke
parents:
diff changeset
    10
// ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
489c9b5090e2 Initial load
duke
parents:
diff changeset
    11
// FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
489c9b5090e2 Initial load
duke
parents:
diff changeset
    12
// version 2 for more details (a copy is included in the LICENSE file that
489c9b5090e2 Initial load
duke
parents:
diff changeset
    13
// accompanied this code).
489c9b5090e2 Initial load
duke
parents:
diff changeset
    14
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
    15
// You should have received a copy of the GNU General Public License version
489c9b5090e2 Initial load
duke
parents:
diff changeset
    16
// 2 along with this work; if not, write to the Free Software Foundation,
489c9b5090e2 Initial load
duke
parents:
diff changeset
    17
// Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    18
//
5547
f4b087cbb361 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 5352
diff changeset
    19
// Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
f4b087cbb361 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 5352
diff changeset
    20
// or visit www.oracle.com if you need additional information or have any
f4b087cbb361 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 5352
diff changeset
    21
// questions.
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    22
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
    23
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
    24
489c9b5090e2 Initial load
duke
parents:
diff changeset
    25
// X86 Architecture Description File
489c9b5090e2 Initial load
duke
parents:
diff changeset
    26
489c9b5090e2 Initial load
duke
parents:
diff changeset
    27
//----------REGISTER DEFINITION BLOCK------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
    28
// This information is used by the matcher and the register allocator to
489c9b5090e2 Initial load
duke
parents:
diff changeset
    29
// describe individual registers and classes of registers within the target
489c9b5090e2 Initial load
duke
parents:
diff changeset
    30
// archtecture.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    31
489c9b5090e2 Initial load
duke
parents:
diff changeset
    32
register %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
    33
//----------Architecture Description Register Definitions----------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
    34
// General Registers
489c9b5090e2 Initial load
duke
parents:
diff changeset
    35
// "reg_def"  name ( register save type, C convention save type,
489c9b5090e2 Initial load
duke
parents:
diff changeset
    36
//                   ideal register type, encoding );
489c9b5090e2 Initial load
duke
parents:
diff changeset
    37
// Register Save Types:
489c9b5090e2 Initial load
duke
parents:
diff changeset
    38
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
    39
// NS  = No-Save:       The register allocator assumes that these registers
489c9b5090e2 Initial load
duke
parents:
diff changeset
    40
//                      can be used without saving upon entry to the method, &
489c9b5090e2 Initial load
duke
parents:
diff changeset
    41
//                      that they do not need to be saved at call sites.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    42
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
    43
// SOC = Save-On-Call:  The register allocator assumes that these registers
489c9b5090e2 Initial load
duke
parents:
diff changeset
    44
//                      can be used without saving upon entry to the method,
489c9b5090e2 Initial load
duke
parents:
diff changeset
    45
//                      but that they must be saved at call sites.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    46
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
    47
// SOE = Save-On-Entry: The register allocator assumes that these registers
489c9b5090e2 Initial load
duke
parents:
diff changeset
    48
//                      must be saved before using them upon entry to the
489c9b5090e2 Initial load
duke
parents:
diff changeset
    49
//                      method, but they do not need to be saved at call
489c9b5090e2 Initial load
duke
parents:
diff changeset
    50
//                      sites.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    51
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
    52
// AS  = Always-Save:   The register allocator assumes that these registers
489c9b5090e2 Initial load
duke
parents:
diff changeset
    53
//                      must be saved before using them upon entry to the
489c9b5090e2 Initial load
duke
parents:
diff changeset
    54
//                      method, & that they must be saved at call sites.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    55
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
    56
// Ideal Register Type is used to determine how to save & restore a
489c9b5090e2 Initial load
duke
parents:
diff changeset
    57
// register.  Op_RegI will get spilled with LoadI/StoreI, Op_RegP will get
489c9b5090e2 Initial load
duke
parents:
diff changeset
    58
// spilled with LoadP/StoreP.  If the register supports both, use Op_RegI.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    59
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
    60
// The encoding number is the actual bit-pattern placed into the opcodes.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    61
489c9b5090e2 Initial load
duke
parents:
diff changeset
    62
// General Registers
489c9b5090e2 Initial load
duke
parents:
diff changeset
    63
// Previously set EBX, ESI, and EDI as save-on-entry for java code
489c9b5090e2 Initial load
duke
parents:
diff changeset
    64
// Turn off SOE in java-code due to frequent use of uncommon-traps.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    65
// Now that allocator is better, turn on ESI and EDI as SOE registers.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    66
489c9b5090e2 Initial load
duke
parents:
diff changeset
    67
reg_def EBX(SOC, SOE, Op_RegI, 3, rbx->as_VMReg());
489c9b5090e2 Initial load
duke
parents:
diff changeset
    68
reg_def ECX(SOC, SOC, Op_RegI, 1, rcx->as_VMReg());
489c9b5090e2 Initial load
duke
parents:
diff changeset
    69
reg_def ESI(SOC, SOE, Op_RegI, 6, rsi->as_VMReg());
489c9b5090e2 Initial load
duke
parents:
diff changeset
    70
reg_def EDI(SOC, SOE, Op_RegI, 7, rdi->as_VMReg());
489c9b5090e2 Initial load
duke
parents:
diff changeset
    71
// now that adapter frames are gone EBP is always saved and restored by the prolog/epilog code
489c9b5090e2 Initial load
duke
parents:
diff changeset
    72
reg_def EBP(NS, SOE, Op_RegI, 5, rbp->as_VMReg());
489c9b5090e2 Initial load
duke
parents:
diff changeset
    73
reg_def EDX(SOC, SOC, Op_RegI, 2, rdx->as_VMReg());
489c9b5090e2 Initial load
duke
parents:
diff changeset
    74
reg_def EAX(SOC, SOC, Op_RegI, 0, rax->as_VMReg());
489c9b5090e2 Initial load
duke
parents:
diff changeset
    75
reg_def ESP( NS,  NS, Op_RegI, 4, rsp->as_VMReg());
489c9b5090e2 Initial load
duke
parents:
diff changeset
    76
489c9b5090e2 Initial load
duke
parents:
diff changeset
    77
// Float registers.  We treat TOS/FPR0 special.  It is invisible to the
489c9b5090e2 Initial load
duke
parents:
diff changeset
    78
// allocator, and only shows up in the encodings.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    79
reg_def FPR0L( SOC, SOC, Op_RegF, 0, VMRegImpl::Bad());
489c9b5090e2 Initial load
duke
parents:
diff changeset
    80
reg_def FPR0H( SOC, SOC, Op_RegF, 0, VMRegImpl::Bad());
489c9b5090e2 Initial load
duke
parents:
diff changeset
    81
// Ok so here's the trick FPR1 is really st(0) except in the midst
489c9b5090e2 Initial load
duke
parents:
diff changeset
    82
// of emission of assembly for a machnode. During the emission the fpu stack
489c9b5090e2 Initial load
duke
parents:
diff changeset
    83
// is pushed making FPR1 == st(1) temporarily. However at any safepoint
489c9b5090e2 Initial load
duke
parents:
diff changeset
    84
// the stack will not have this element so FPR1 == st(0) from the
489c9b5090e2 Initial load
duke
parents:
diff changeset
    85
// oopMap viewpoint. This same weirdness with numbering causes
489c9b5090e2 Initial load
duke
parents:
diff changeset
    86
// instruction encoding to have to play games with the register
489c9b5090e2 Initial load
duke
parents:
diff changeset
    87
// encode to correct for this 0/1 issue. See MachSpillCopyNode::implementation
489c9b5090e2 Initial load
duke
parents:
diff changeset
    88
// where it does flt->flt moves to see an example
489c9b5090e2 Initial load
duke
parents:
diff changeset
    89
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
    90
reg_def FPR1L( SOC, SOC, Op_RegF, 1, as_FloatRegister(0)->as_VMReg());
489c9b5090e2 Initial load
duke
parents:
diff changeset
    91
reg_def FPR1H( SOC, SOC, Op_RegF, 1, as_FloatRegister(0)->as_VMReg()->next());
489c9b5090e2 Initial load
duke
parents:
diff changeset
    92
reg_def FPR2L( SOC, SOC, Op_RegF, 2, as_FloatRegister(1)->as_VMReg());
489c9b5090e2 Initial load
duke
parents:
diff changeset
    93
reg_def FPR2H( SOC, SOC, Op_RegF, 2, as_FloatRegister(1)->as_VMReg()->next());
489c9b5090e2 Initial load
duke
parents:
diff changeset
    94
reg_def FPR3L( SOC, SOC, Op_RegF, 3, as_FloatRegister(2)->as_VMReg());
489c9b5090e2 Initial load
duke
parents:
diff changeset
    95
reg_def FPR3H( SOC, SOC, Op_RegF, 3, as_FloatRegister(2)->as_VMReg()->next());
489c9b5090e2 Initial load
duke
parents:
diff changeset
    96
reg_def FPR4L( SOC, SOC, Op_RegF, 4, as_FloatRegister(3)->as_VMReg());
489c9b5090e2 Initial load
duke
parents:
diff changeset
    97
reg_def FPR4H( SOC, SOC, Op_RegF, 4, as_FloatRegister(3)->as_VMReg()->next());
489c9b5090e2 Initial load
duke
parents:
diff changeset
    98
reg_def FPR5L( SOC, SOC, Op_RegF, 5, as_FloatRegister(4)->as_VMReg());
489c9b5090e2 Initial load
duke
parents:
diff changeset
    99
reg_def FPR5H( SOC, SOC, Op_RegF, 5, as_FloatRegister(4)->as_VMReg()->next());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   100
reg_def FPR6L( SOC, SOC, Op_RegF, 6, as_FloatRegister(5)->as_VMReg());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   101
reg_def FPR6H( SOC, SOC, Op_RegF, 6, as_FloatRegister(5)->as_VMReg()->next());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   102
reg_def FPR7L( SOC, SOC, Op_RegF, 7, as_FloatRegister(6)->as_VMReg());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   103
reg_def FPR7H( SOC, SOC, Op_RegF, 7, as_FloatRegister(6)->as_VMReg()->next());
30624
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
   104
//
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
   105
// Empty fill registers, which are never used, but supply alignment to xmm regs
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
   106
//
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
   107
reg_def FILL0( SOC, SOC, Op_RegF, 7, as_FloatRegister(6)->as_VMReg()->next(2));
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
   108
reg_def FILL1( SOC, SOC, Op_RegF, 7, as_FloatRegister(6)->as_VMReg()->next(3));
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
   109
reg_def FILL2( SOC, SOC, Op_RegF, 7, as_FloatRegister(6)->as_VMReg()->next(4));
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
   110
reg_def FILL3( SOC, SOC, Op_RegF, 7, as_FloatRegister(6)->as_VMReg()->next(5));
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
   111
reg_def FILL4( SOC, SOC, Op_RegF, 7, as_FloatRegister(6)->as_VMReg()->next(6));
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
   112
reg_def FILL5( SOC, SOC, Op_RegF, 7, as_FloatRegister(6)->as_VMReg()->next(7));
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
   113
reg_def FILL6( SOC, SOC, Op_RegF, 7, as_FloatRegister(6)->as_VMReg()->next(8));
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
   114
reg_def FILL7( SOC, SOC, Op_RegF, 7, as_FloatRegister(6)->as_VMReg()->next(9));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   115
489c9b5090e2 Initial load
duke
parents:
diff changeset
   116
// Specify priority of register selection within phases of register
489c9b5090e2 Initial load
duke
parents:
diff changeset
   117
// allocation.  Highest priority is first.  A useful heuristic is to
489c9b5090e2 Initial load
duke
parents:
diff changeset
   118
// give registers a low priority when they are required by machine
489c9b5090e2 Initial load
duke
parents:
diff changeset
   119
// instructions, like EAX and EDX.  Registers which are used as
2131
98f9cef66a34 6810672: Comment typos
twisti
parents: 2034
diff changeset
   120
// pairs must fall on an even boundary (witness the FPR#L's in this list).
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   121
// For the Intel integer registers, the equivalent Long pairs are
489c9b5090e2 Initial load
duke
parents:
diff changeset
   122
// EDX:EAX, EBX:ECX, and EDI:EBP.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   123
alloc_class chunk0( ECX,   EBX,   EBP,   EDI,   EAX,   EDX,   ESI, ESP,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   124
                    FPR0L, FPR0H, FPR1L, FPR1H, FPR2L, FPR2H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   125
                    FPR3L, FPR3H, FPR4L, FPR4H, FPR5L, FPR5H,
30624
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
   126
                    FPR6L, FPR6H, FPR7L, FPR7H,
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
   127
                    FILL0, FILL1, FILL2, FILL3, FILL4, FILL5, FILL6, FILL7);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   128
489c9b5090e2 Initial load
duke
parents:
diff changeset
   129
489c9b5090e2 Initial load
duke
parents:
diff changeset
   130
//----------Architecture Description Register Classes--------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
   131
// Several register classes are automatically defined based upon information in
489c9b5090e2 Initial load
duke
parents:
diff changeset
   132
// this architecture description.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   133
// 1) reg_class inline_cache_reg           ( /* as def'd in frame section */ )
489c9b5090e2 Initial load
duke
parents:
diff changeset
   134
// 2) reg_class compiler_method_oop_reg    ( /* as def'd in frame section */ )
489c9b5090e2 Initial load
duke
parents:
diff changeset
   135
// 2) reg_class interpreter_method_oop_reg ( /* as def'd in frame section */ )
489c9b5090e2 Initial load
duke
parents:
diff changeset
   136
// 3) reg_class stack_slots( /* one chunk of stack-based "registers" */ )
489c9b5090e2 Initial load
duke
parents:
diff changeset
   137
//
30305
b92a97e1e9cb 8068945: Use RBP register as proper frame pointer in JIT compiled code on x86
zmajo
parents: 28954
diff changeset
   138
// Class for no registers (empty set).
b92a97e1e9cb 8068945: Use RBP register as proper frame pointer in JIT compiled code on x86
zmajo
parents: 28954
diff changeset
   139
reg_class no_reg();
b92a97e1e9cb 8068945: Use RBP register as proper frame pointer in JIT compiled code on x86
zmajo
parents: 28954
diff changeset
   140
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   141
// Class for all registers
30305
b92a97e1e9cb 8068945: Use RBP register as proper frame pointer in JIT compiled code on x86
zmajo
parents: 28954
diff changeset
   142
reg_class any_reg_with_ebp(EAX, EDX, EBP, EDI, ESI, ECX, EBX, ESP);
b92a97e1e9cb 8068945: Use RBP register as proper frame pointer in JIT compiled code on x86
zmajo
parents: 28954
diff changeset
   143
// Class for all registers (excluding EBP)
b92a97e1e9cb 8068945: Use RBP register as proper frame pointer in JIT compiled code on x86
zmajo
parents: 28954
diff changeset
   144
reg_class any_reg_no_ebp(EAX, EDX, EDI, ESI, ECX, EBX, ESP);
b92a97e1e9cb 8068945: Use RBP register as proper frame pointer in JIT compiled code on x86
zmajo
parents: 28954
diff changeset
   145
// Dynamic register class that selects at runtime between register classes
30624
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
   146
// any_reg and any_no_ebp_reg (depending on the value of the flag PreserveFramePointer).
30305
b92a97e1e9cb 8068945: Use RBP register as proper frame pointer in JIT compiled code on x86
zmajo
parents: 28954
diff changeset
   147
// Equivalent to: return PreserveFramePointer ? any_no_ebp_reg : any_reg;
b92a97e1e9cb 8068945: Use RBP register as proper frame pointer in JIT compiled code on x86
zmajo
parents: 28954
diff changeset
   148
reg_class_dynamic any_reg(any_reg_no_ebp, any_reg_with_ebp, %{ PreserveFramePointer %});
b92a97e1e9cb 8068945: Use RBP register as proper frame pointer in JIT compiled code on x86
zmajo
parents: 28954
diff changeset
   149
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   150
// Class for general registers
30305
b92a97e1e9cb 8068945: Use RBP register as proper frame pointer in JIT compiled code on x86
zmajo
parents: 28954
diff changeset
   151
reg_class int_reg_with_ebp(EAX, EDX, EBP, EDI, ESI, ECX, EBX);
b92a97e1e9cb 8068945: Use RBP register as proper frame pointer in JIT compiled code on x86
zmajo
parents: 28954
diff changeset
   152
// Class for general registers (excluding EBP).
b92a97e1e9cb 8068945: Use RBP register as proper frame pointer in JIT compiled code on x86
zmajo
parents: 28954
diff changeset
   153
// This register class can be used for implicit null checks on win95.
b92a97e1e9cb 8068945: Use RBP register as proper frame pointer in JIT compiled code on x86
zmajo
parents: 28954
diff changeset
   154
// It is also safe for use by tailjumps (we don't want to allocate in ebp).
b92a97e1e9cb 8068945: Use RBP register as proper frame pointer in JIT compiled code on x86
zmajo
parents: 28954
diff changeset
   155
// Used also if the PreserveFramePointer flag is true.
b92a97e1e9cb 8068945: Use RBP register as proper frame pointer in JIT compiled code on x86
zmajo
parents: 28954
diff changeset
   156
reg_class int_reg_no_ebp(EAX, EDX, EDI, ESI, ECX, EBX);
b92a97e1e9cb 8068945: Use RBP register as proper frame pointer in JIT compiled code on x86
zmajo
parents: 28954
diff changeset
   157
// Dynamic register class that selects between int_reg and int_reg_no_ebp.
b92a97e1e9cb 8068945: Use RBP register as proper frame pointer in JIT compiled code on x86
zmajo
parents: 28954
diff changeset
   158
reg_class_dynamic int_reg(int_reg_no_ebp, int_reg_with_ebp, %{ PreserveFramePointer %});
b92a97e1e9cb 8068945: Use RBP register as proper frame pointer in JIT compiled code on x86
zmajo
parents: 28954
diff changeset
   159
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   160
// Class of "X" registers
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
   161
reg_class int_x_reg(EBX, ECX, EDX, EAX);
30305
b92a97e1e9cb 8068945: Use RBP register as proper frame pointer in JIT compiled code on x86
zmajo
parents: 28954
diff changeset
   162
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   163
// Class of registers that can appear in an address with no offset.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   164
// EBP and ESP require an extra instruction byte for zero offset.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   165
// Used in fast-unlock
489c9b5090e2 Initial load
duke
parents:
diff changeset
   166
reg_class p_reg(EDX, EDI, ESI, EBX);
30305
b92a97e1e9cb 8068945: Use RBP register as proper frame pointer in JIT compiled code on x86
zmajo
parents: 28954
diff changeset
   167
b92a97e1e9cb 8068945: Use RBP register as proper frame pointer in JIT compiled code on x86
zmajo
parents: 28954
diff changeset
   168
// Class for general registers excluding ECX
b92a97e1e9cb 8068945: Use RBP register as proper frame pointer in JIT compiled code on x86
zmajo
parents: 28954
diff changeset
   169
reg_class ncx_reg_with_ebp(EAX, EDX, EBP, EDI, ESI, EBX);
b92a97e1e9cb 8068945: Use RBP register as proper frame pointer in JIT compiled code on x86
zmajo
parents: 28954
diff changeset
   170
// Class for general registers excluding ECX (and EBP)
b92a97e1e9cb 8068945: Use RBP register as proper frame pointer in JIT compiled code on x86
zmajo
parents: 28954
diff changeset
   171
reg_class ncx_reg_no_ebp(EAX, EDX, EDI, ESI, EBX);
b92a97e1e9cb 8068945: Use RBP register as proper frame pointer in JIT compiled code on x86
zmajo
parents: 28954
diff changeset
   172
// Dynamic register class that selects between ncx_reg and ncx_reg_no_ebp.
b92a97e1e9cb 8068945: Use RBP register as proper frame pointer in JIT compiled code on x86
zmajo
parents: 28954
diff changeset
   173
reg_class_dynamic ncx_reg(ncx_reg_no_ebp, ncx_reg_with_ebp, %{ PreserveFramePointer %});
b92a97e1e9cb 8068945: Use RBP register as proper frame pointer in JIT compiled code on x86
zmajo
parents: 28954
diff changeset
   174
b92a97e1e9cb 8068945: Use RBP register as proper frame pointer in JIT compiled code on x86
zmajo
parents: 28954
diff changeset
   175
// Class for general registers excluding EAX
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   176
reg_class nax_reg(EDX, EDI, ESI, ECX, EBX);
30305
b92a97e1e9cb 8068945: Use RBP register as proper frame pointer in JIT compiled code on x86
zmajo
parents: 28954
diff changeset
   177
b92a97e1e9cb 8068945: Use RBP register as proper frame pointer in JIT compiled code on x86
zmajo
parents: 28954
diff changeset
   178
// Class for general registers excluding EAX and EBX.
b92a97e1e9cb 8068945: Use RBP register as proper frame pointer in JIT compiled code on x86
zmajo
parents: 28954
diff changeset
   179
reg_class nabx_reg_with_ebp(EDX, EDI, ESI, ECX, EBP);
b92a97e1e9cb 8068945: Use RBP register as proper frame pointer in JIT compiled code on x86
zmajo
parents: 28954
diff changeset
   180
// Class for general registers excluding EAX and EBX (and EBP)
b92a97e1e9cb 8068945: Use RBP register as proper frame pointer in JIT compiled code on x86
zmajo
parents: 28954
diff changeset
   181
reg_class nabx_reg_no_ebp(EDX, EDI, ESI, ECX);
b92a97e1e9cb 8068945: Use RBP register as proper frame pointer in JIT compiled code on x86
zmajo
parents: 28954
diff changeset
   182
// Dynamic register class that selects between nabx_reg and nabx_reg_no_ebp.
b92a97e1e9cb 8068945: Use RBP register as proper frame pointer in JIT compiled code on x86
zmajo
parents: 28954
diff changeset
   183
reg_class_dynamic nabx_reg(nabx_reg_no_ebp, nabx_reg_with_ebp, %{ PreserveFramePointer %});
b92a97e1e9cb 8068945: Use RBP register as proper frame pointer in JIT compiled code on x86
zmajo
parents: 28954
diff changeset
   184
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   185
// Class of EAX (for multiply and divide operations)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   186
reg_class eax_reg(EAX);
30305
b92a97e1e9cb 8068945: Use RBP register as proper frame pointer in JIT compiled code on x86
zmajo
parents: 28954
diff changeset
   187
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   188
// Class of EBX (for atomic add)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   189
reg_class ebx_reg(EBX);
30305
b92a97e1e9cb 8068945: Use RBP register as proper frame pointer in JIT compiled code on x86
zmajo
parents: 28954
diff changeset
   190
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   191
// Class of ECX (for shift and JCXZ operations and cmpLTMask)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   192
reg_class ecx_reg(ECX);
30305
b92a97e1e9cb 8068945: Use RBP register as proper frame pointer in JIT compiled code on x86
zmajo
parents: 28954
diff changeset
   193
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   194
// Class of EDX (for multiply and divide operations)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   195
reg_class edx_reg(EDX);
30305
b92a97e1e9cb 8068945: Use RBP register as proper frame pointer in JIT compiled code on x86
zmajo
parents: 28954
diff changeset
   196
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   197
// Class of EDI (for synchronization)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   198
reg_class edi_reg(EDI);
30305
b92a97e1e9cb 8068945: Use RBP register as proper frame pointer in JIT compiled code on x86
zmajo
parents: 28954
diff changeset
   199
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   200
// Class of ESI (for synchronization)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   201
reg_class esi_reg(ESI);
30305
b92a97e1e9cb 8068945: Use RBP register as proper frame pointer in JIT compiled code on x86
zmajo
parents: 28954
diff changeset
   202
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   203
// Singleton class for stack pointer
489c9b5090e2 Initial load
duke
parents:
diff changeset
   204
reg_class sp_reg(ESP);
30305
b92a97e1e9cb 8068945: Use RBP register as proper frame pointer in JIT compiled code on x86
zmajo
parents: 28954
diff changeset
   205
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   206
// Singleton class for instruction pointer
489c9b5090e2 Initial load
duke
parents:
diff changeset
   207
// reg_class ip_reg(EIP);
30305
b92a97e1e9cb 8068945: Use RBP register as proper frame pointer in JIT compiled code on x86
zmajo
parents: 28954
diff changeset
   208
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   209
// Class of integer register pairs
30305
b92a97e1e9cb 8068945: Use RBP register as proper frame pointer in JIT compiled code on x86
zmajo
parents: 28954
diff changeset
   210
reg_class long_reg_with_ebp( EAX,EDX, ECX,EBX, EBP,EDI );
b92a97e1e9cb 8068945: Use RBP register as proper frame pointer in JIT compiled code on x86
zmajo
parents: 28954
diff changeset
   211
// Class of integer register pairs (excluding EBP and EDI);
b92a97e1e9cb 8068945: Use RBP register as proper frame pointer in JIT compiled code on x86
zmajo
parents: 28954
diff changeset
   212
reg_class long_reg_no_ebp( EAX,EDX, ECX,EBX );
b92a97e1e9cb 8068945: Use RBP register as proper frame pointer in JIT compiled code on x86
zmajo
parents: 28954
diff changeset
   213
// Dynamic register class that selects between long_reg and long_reg_no_ebp.
b92a97e1e9cb 8068945: Use RBP register as proper frame pointer in JIT compiled code on x86
zmajo
parents: 28954
diff changeset
   214
reg_class_dynamic long_reg(long_reg_no_ebp, long_reg_with_ebp, %{ PreserveFramePointer %});
b92a97e1e9cb 8068945: Use RBP register as proper frame pointer in JIT compiled code on x86
zmajo
parents: 28954
diff changeset
   215
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   216
// Class of integer register pairs that aligns with calling convention
489c9b5090e2 Initial load
duke
parents:
diff changeset
   217
reg_class eadx_reg( EAX,EDX );
489c9b5090e2 Initial load
duke
parents:
diff changeset
   218
reg_class ebcx_reg( ECX,EBX );
30305
b92a97e1e9cb 8068945: Use RBP register as proper frame pointer in JIT compiled code on x86
zmajo
parents: 28954
diff changeset
   219
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   220
// Not AX or DX, used in divides
30305
b92a97e1e9cb 8068945: Use RBP register as proper frame pointer in JIT compiled code on x86
zmajo
parents: 28954
diff changeset
   221
reg_class nadx_reg_with_ebp(EBX, ECX, ESI, EDI, EBP);
b92a97e1e9cb 8068945: Use RBP register as proper frame pointer in JIT compiled code on x86
zmajo
parents: 28954
diff changeset
   222
// Not AX or DX (and neither EBP), used in divides
b92a97e1e9cb 8068945: Use RBP register as proper frame pointer in JIT compiled code on x86
zmajo
parents: 28954
diff changeset
   223
reg_class nadx_reg_no_ebp(EBX, ECX, ESI, EDI);
b92a97e1e9cb 8068945: Use RBP register as proper frame pointer in JIT compiled code on x86
zmajo
parents: 28954
diff changeset
   224
// Dynamic register class that selects between nadx_reg and nadx_reg_no_ebp.
b92a97e1e9cb 8068945: Use RBP register as proper frame pointer in JIT compiled code on x86
zmajo
parents: 28954
diff changeset
   225
reg_class_dynamic nadx_reg(nadx_reg_no_ebp, nadx_reg_with_ebp, %{ PreserveFramePointer %});
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   226
489c9b5090e2 Initial load
duke
parents:
diff changeset
   227
// Floating point registers.  Notice FPR0 is not a choice.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   228
// FPR0 is not ever allocated; we use clever encodings to fake
489c9b5090e2 Initial load
duke
parents:
diff changeset
   229
// a 2-address instructions out of Intels FP stack.
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
   230
reg_class fp_flt_reg( FPR1L,FPR2L,FPR3L,FPR4L,FPR5L,FPR6L,FPR7L );
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
   231
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
   232
reg_class fp_dbl_reg( FPR1L,FPR1H, FPR2L,FPR2H, FPR3L,FPR3H,
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
   233
                      FPR4L,FPR4H, FPR5L,FPR5H, FPR6L,FPR6H,
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
   234
                      FPR7L,FPR7H );
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
   235
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
   236
reg_class fp_flt_reg0( FPR1L );
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
   237
reg_class fp_dbl_reg0( FPR1L,FPR1H );
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
   238
reg_class fp_dbl_reg1( FPR2L,FPR2H );
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
   239
reg_class fp_dbl_notreg0( FPR2L,FPR2H, FPR3L,FPR3H, FPR4L,FPR4H,
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
   240
                          FPR5L,FPR5H, FPR6L,FPR6H, FPR7L,FPR7H );
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
   241
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   242
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   243
489c9b5090e2 Initial load
duke
parents:
diff changeset
   244
489c9b5090e2 Initial load
duke
parents:
diff changeset
   245
//----------SOURCE BLOCK-------------------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
   246
// This is a block of C++ code which provides values, functions, and
489c9b5090e2 Initial load
duke
parents:
diff changeset
   247
// definitions necessary in the rest of the architecture description
4757
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
   248
source_hpp %{
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
   249
// Must be visible to the DFA in dfa_x86_32.cpp
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
   250
extern bool is_operand_hi32_zero(Node* n);
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
   251
%}
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
   252
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   253
source %{
1066
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
   254
#define   RELOC_IMM32    Assembler::imm_operand
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   255
#define   RELOC_DISP32   Assembler::disp32_operand
489c9b5090e2 Initial load
duke
parents:
diff changeset
   256
489c9b5090e2 Initial load
duke
parents:
diff changeset
   257
#define __ _masm.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   258
489c9b5090e2 Initial load
duke
parents:
diff changeset
   259
// How to find the high register of a Long pair, given the low register
489c9b5090e2 Initial load
duke
parents:
diff changeset
   260
#define   HIGH_FROM_LOW(x) ((x)+2)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   261
489c9b5090e2 Initial load
duke
parents:
diff changeset
   262
// These masks are used to provide 128-bit aligned bitmasks to the XMM
489c9b5090e2 Initial load
duke
parents:
diff changeset
   263
// instructions, to allow sign-masking or sign-bit flipping.  They allow
489c9b5090e2 Initial load
duke
parents:
diff changeset
   264
// fast versions of NegF/NegD and AbsF/AbsD.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   265
489c9b5090e2 Initial load
duke
parents:
diff changeset
   266
// Note: 'double' and 'long long' have 32-bits alignment on x86.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   267
static jlong* double_quadword(jlong *adr, jlong lo, jlong hi) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   268
  // Use the expression (adr)&(~0xF) to provide 128-bits aligned address
489c9b5090e2 Initial load
duke
parents:
diff changeset
   269
  // of 128-bits operands for SSE instructions.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   270
  jlong *operand = (jlong*)(((uintptr_t)adr)&((uintptr_t)(~0xF)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
   271
  // Store the value to a 128-bits operand.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   272
  operand[0] = lo;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   273
  operand[1] = hi;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   274
  return operand;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   275
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   276
489c9b5090e2 Initial load
duke
parents:
diff changeset
   277
// Buffer for 128-bits masks used by SSE instructions.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   278
static jlong fp_signmask_pool[(4+1)*2]; // 4*128bits(data) + 128bits(alignment)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   279
489c9b5090e2 Initial load
duke
parents:
diff changeset
   280
// Static initialization during VM startup.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   281
static jlong *float_signmask_pool  = double_quadword(&fp_signmask_pool[1*2], CONST64(0x7FFFFFFF7FFFFFFF), CONST64(0x7FFFFFFF7FFFFFFF));
489c9b5090e2 Initial load
duke
parents:
diff changeset
   282
static jlong *double_signmask_pool = double_quadword(&fp_signmask_pool[2*2], CONST64(0x7FFFFFFFFFFFFFFF), CONST64(0x7FFFFFFFFFFFFFFF));
489c9b5090e2 Initial load
duke
parents:
diff changeset
   283
static jlong *float_signflip_pool  = double_quadword(&fp_signmask_pool[3*2], CONST64(0x8000000080000000), CONST64(0x8000000080000000));
489c9b5090e2 Initial load
duke
parents:
diff changeset
   284
static jlong *double_signflip_pool = double_quadword(&fp_signmask_pool[4*2], CONST64(0x8000000000000000), CONST64(0x8000000000000000));
489c9b5090e2 Initial load
duke
parents:
diff changeset
   285
4566
b363f6ef4068 6829187: compiler optimizations required for JSR 292
twisti
parents: 3908
diff changeset
   286
// Offset hacking within calls.
16624
9dbd4b210bf9 8011102: Clear AVX registers after return from JNI call
kvn
parents: 15242
diff changeset
   287
static int pre_call_resets_size() {
9dbd4b210bf9 8011102: Clear AVX registers after return from JNI call
kvn
parents: 15242
diff changeset
   288
  int size = 0;
9dbd4b210bf9 8011102: Clear AVX registers after return from JNI call
kvn
parents: 15242
diff changeset
   289
  Compile* C = Compile::current();
9dbd4b210bf9 8011102: Clear AVX registers after return from JNI call
kvn
parents: 15242
diff changeset
   290
  if (C->in_24_bit_fp_mode()) {
9dbd4b210bf9 8011102: Clear AVX registers after return from JNI call
kvn
parents: 15242
diff changeset
   291
    size += 6; // fldcw
9dbd4b210bf9 8011102: Clear AVX registers after return from JNI call
kvn
parents: 15242
diff changeset
   292
  }
9dbd4b210bf9 8011102: Clear AVX registers after return from JNI call
kvn
parents: 15242
diff changeset
   293
  if (C->max_vector_size() > 16) {
30624
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
   294
    if(UseAVX <= 2) {
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
   295
      size += 3; // vzeroupper
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
   296
    }
16624
9dbd4b210bf9 8011102: Clear AVX registers after return from JNI call
kvn
parents: 15242
diff changeset
   297
  }
9dbd4b210bf9 8011102: Clear AVX registers after return from JNI call
kvn
parents: 15242
diff changeset
   298
  return size;
4566
b363f6ef4068 6829187: compiler optimizations required for JSR 292
twisti
parents: 3908
diff changeset
   299
}
b363f6ef4068 6829187: compiler optimizations required for JSR 292
twisti
parents: 3908
diff changeset
   300
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   301
// !!!!! Special hack to get all type of calls to specify the byte offset
489c9b5090e2 Initial load
duke
parents:
diff changeset
   302
//       from the start of the call to the point where the return address
489c9b5090e2 Initial load
duke
parents:
diff changeset
   303
//       will point.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   304
int MachCallStaticJavaNode::ret_addr_offset() {
30624
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
   305
  return 5 + pre_call_resets_size();  // 5 bytes from start of call to where return address points
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   306
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   307
489c9b5090e2 Initial load
duke
parents:
diff changeset
   308
int MachCallDynamicJavaNode::ret_addr_offset() {
16624
9dbd4b210bf9 8011102: Clear AVX registers after return from JNI call
kvn
parents: 15242
diff changeset
   309
  return 10 + pre_call_resets_size();  // 10 bytes from start of call to where return address points
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   310
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   311
489c9b5090e2 Initial load
duke
parents:
diff changeset
   312
static int sizeof_FFree_Float_Stack_All = -1;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   313
489c9b5090e2 Initial load
duke
parents:
diff changeset
   314
int MachCallRuntimeNode::ret_addr_offset() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   315
  assert(sizeof_FFree_Float_Stack_All != -1, "must have been emitted already");
16624
9dbd4b210bf9 8011102: Clear AVX registers after return from JNI call
kvn
parents: 15242
diff changeset
   316
  return sizeof_FFree_Float_Stack_All + 5 + pre_call_resets_size();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   317
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   318
489c9b5090e2 Initial load
duke
parents:
diff changeset
   319
// Indicate if the safepoint node needs the polling page as an input.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   320
// Since x86 does have absolute addressing, it doesn't.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   321
bool SafePointNode::needs_polling_address_input() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   322
  return false;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   323
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   324
489c9b5090e2 Initial load
duke
parents:
diff changeset
   325
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
   326
// Compute padding required for nodes which need alignment
489c9b5090e2 Initial load
duke
parents:
diff changeset
   327
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
   328
489c9b5090e2 Initial load
duke
parents:
diff changeset
   329
// The address of the call instruction needs to be 4-byte aligned to
489c9b5090e2 Initial load
duke
parents:
diff changeset
   330
// ensure that it does not span a cache line so that it can be patched.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   331
int CallStaticJavaDirectNode::compute_padding(int current_offset) const {
16624
9dbd4b210bf9 8011102: Clear AVX registers after return from JNI call
kvn
parents: 15242
diff changeset
   332
  current_offset += pre_call_resets_size();  // skip fldcw, if any
4566
b363f6ef4068 6829187: compiler optimizations required for JSR 292
twisti
parents: 3908
diff changeset
   333
  current_offset += 1;      // skip call opcode byte
b363f6ef4068 6829187: compiler optimizations required for JSR 292
twisti
parents: 3908
diff changeset
   334
  return round_to(current_offset, alignment_required()) - current_offset;
b363f6ef4068 6829187: compiler optimizations required for JSR 292
twisti
parents: 3908
diff changeset
   335
}
b363f6ef4068 6829187: compiler optimizations required for JSR 292
twisti
parents: 3908
diff changeset
   336
b363f6ef4068 6829187: compiler optimizations required for JSR 292
twisti
parents: 3908
diff changeset
   337
// The address of the call instruction needs to be 4-byte aligned to
b363f6ef4068 6829187: compiler optimizations required for JSR 292
twisti
parents: 3908
diff changeset
   338
// ensure that it does not span a cache line so that it can be patched.
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   339
int CallDynamicJavaDirectNode::compute_padding(int current_offset) const {
16624
9dbd4b210bf9 8011102: Clear AVX registers after return from JNI call
kvn
parents: 15242
diff changeset
   340
  current_offset += pre_call_resets_size();  // skip fldcw, if any
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   341
  current_offset += 5;      // skip MOV instruction
489c9b5090e2 Initial load
duke
parents:
diff changeset
   342
  current_offset += 1;      // skip call opcode byte
489c9b5090e2 Initial load
duke
parents:
diff changeset
   343
  return round_to(current_offset, alignment_required()) - current_offset;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   344
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   345
489c9b5090e2 Initial load
duke
parents:
diff changeset
   346
// EMIT_RM()
489c9b5090e2 Initial load
duke
parents:
diff changeset
   347
void emit_rm(CodeBuffer &cbuf, int f1, int f2, int f3) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   348
  unsigned char c = (unsigned char)((f1 << 6) | (f2 << 3) | f3);
6418
6671edbd230e 6978355: renaming for 6961697
twisti
parents: 6272
diff changeset
   349
  cbuf.insts()->emit_int8(c);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   350
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   351
489c9b5090e2 Initial load
duke
parents:
diff changeset
   352
// EMIT_CC()
489c9b5090e2 Initial load
duke
parents:
diff changeset
   353
void emit_cc(CodeBuffer &cbuf, int f1, int f2) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   354
  unsigned char c = (unsigned char)( f1 | f2 );
6418
6671edbd230e 6978355: renaming for 6961697
twisti
parents: 6272
diff changeset
   355
  cbuf.insts()->emit_int8(c);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   356
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   357
489c9b5090e2 Initial load
duke
parents:
diff changeset
   358
// EMIT_OPCODE()
489c9b5090e2 Initial load
duke
parents:
diff changeset
   359
void emit_opcode(CodeBuffer &cbuf, int code) {
6418
6671edbd230e 6978355: renaming for 6961697
twisti
parents: 6272
diff changeset
   360
  cbuf.insts()->emit_int8((unsigned char) code);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   361
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   362
489c9b5090e2 Initial load
duke
parents:
diff changeset
   363
// EMIT_OPCODE() w/ relocation information
489c9b5090e2 Initial load
duke
parents:
diff changeset
   364
void emit_opcode(CodeBuffer &cbuf, int code, relocInfo::relocType reloc, int offset = 0) {
6418
6671edbd230e 6978355: renaming for 6961697
twisti
parents: 6272
diff changeset
   365
  cbuf.relocate(cbuf.insts_mark() + offset, reloc);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   366
  emit_opcode(cbuf, code);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   367
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   368
489c9b5090e2 Initial load
duke
parents:
diff changeset
   369
// EMIT_D8()
489c9b5090e2 Initial load
duke
parents:
diff changeset
   370
void emit_d8(CodeBuffer &cbuf, int d8) {
6418
6671edbd230e 6978355: renaming for 6961697
twisti
parents: 6272
diff changeset
   371
  cbuf.insts()->emit_int8((unsigned char) d8);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   372
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   373
489c9b5090e2 Initial load
duke
parents:
diff changeset
   374
// EMIT_D16()
489c9b5090e2 Initial load
duke
parents:
diff changeset
   375
void emit_d16(CodeBuffer &cbuf, int d16) {
6418
6671edbd230e 6978355: renaming for 6961697
twisti
parents: 6272
diff changeset
   376
  cbuf.insts()->emit_int16(d16);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   377
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   378
489c9b5090e2 Initial load
duke
parents:
diff changeset
   379
// EMIT_D32()
489c9b5090e2 Initial load
duke
parents:
diff changeset
   380
void emit_d32(CodeBuffer &cbuf, int d32) {
6418
6671edbd230e 6978355: renaming for 6961697
twisti
parents: 6272
diff changeset
   381
  cbuf.insts()->emit_int32(d32);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   382
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   383
489c9b5090e2 Initial load
duke
parents:
diff changeset
   384
// emit 32 bit value and construct relocation entry from relocInfo::relocType
489c9b5090e2 Initial load
duke
parents:
diff changeset
   385
void emit_d32_reloc(CodeBuffer &cbuf, int d32, relocInfo::relocType reloc,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   386
        int format) {
6418
6671edbd230e 6978355: renaming for 6961697
twisti
parents: 6272
diff changeset
   387
  cbuf.relocate(cbuf.insts_mark(), reloc, format);
6671edbd230e 6978355: renaming for 6961697
twisti
parents: 6272
diff changeset
   388
  cbuf.insts()->emit_int32(d32);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   389
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   390
489c9b5090e2 Initial load
duke
parents:
diff changeset
   391
// emit 32 bit value and construct relocation entry from RelocationHolder
489c9b5090e2 Initial load
duke
parents:
diff changeset
   392
void emit_d32_reloc(CodeBuffer &cbuf, int d32, RelocationHolder const& rspec,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   393
        int format) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   394
#ifdef ASSERT
489c9b5090e2 Initial load
duke
parents:
diff changeset
   395
  if (rspec.reloc()->type() == relocInfo::oop_type && d32 != 0 && d32 != (int)Universe::non_oop_word()) {
20282
7f9cbdf89af2 7195622: CheckUnhandledOops has limited usefulness now
hseigel
parents: 17095
diff changeset
   396
    assert(cast_to_oop(d32)->is_oop() && (ScavengeRootsInCode || !cast_to_oop(d32)->is_scavengable()), "cannot embed scavengable oops in code");
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   397
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   398
#endif
6418
6671edbd230e 6978355: renaming for 6961697
twisti
parents: 6272
diff changeset
   399
  cbuf.relocate(cbuf.insts_mark(), rspec, format);
6671edbd230e 6978355: renaming for 6961697
twisti
parents: 6272
diff changeset
   400
  cbuf.insts()->emit_int32(d32);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   401
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   402
489c9b5090e2 Initial load
duke
parents:
diff changeset
   403
// Access stack slot for load or store
489c9b5090e2 Initial load
duke
parents:
diff changeset
   404
void store_to_stackslot(CodeBuffer &cbuf, int opcode, int rm_field, int disp) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   405
  emit_opcode( cbuf, opcode );               // (e.g., FILD   [ESP+src])
489c9b5090e2 Initial load
duke
parents:
diff changeset
   406
  if( -128 <= disp && disp <= 127 ) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   407
    emit_rm( cbuf, 0x01, rm_field, ESP_enc );  // R/M byte
489c9b5090e2 Initial load
duke
parents:
diff changeset
   408
    emit_rm( cbuf, 0x00, ESP_enc, ESP_enc);    // SIB byte
489c9b5090e2 Initial load
duke
parents:
diff changeset
   409
    emit_d8 (cbuf, disp);     // Displacement  // R/M byte
489c9b5090e2 Initial load
duke
parents:
diff changeset
   410
  } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   411
    emit_rm( cbuf, 0x02, rm_field, ESP_enc );  // R/M byte
489c9b5090e2 Initial load
duke
parents:
diff changeset
   412
    emit_rm( cbuf, 0x00, ESP_enc, ESP_enc);    // SIB byte
489c9b5090e2 Initial load
duke
parents:
diff changeset
   413
    emit_d32(cbuf, disp);     // Displacement  // R/M byte
489c9b5090e2 Initial load
duke
parents:
diff changeset
   414
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   415
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   416
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
   417
   // rRegI ereg, memory mem) %{    // emit_reg_mem
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13485
diff changeset
   418
void encode_RegMem( CodeBuffer &cbuf, int reg_encoding, int base, int index, int scale, int displace, relocInfo::relocType disp_reloc ) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   419
  // There is no index & no scale, use form without SIB byte
489c9b5090e2 Initial load
duke
parents:
diff changeset
   420
  if ((index == 0x4) &&
489c9b5090e2 Initial load
duke
parents:
diff changeset
   421
      (scale == 0) && (base != ESP_enc)) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   422
    // If no displacement, mode is 0x0; unless base is [EBP]
489c9b5090e2 Initial load
duke
parents:
diff changeset
   423
    if ( (displace == 0) && (base != EBP_enc) ) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   424
      emit_rm(cbuf, 0x0, reg_encoding, base);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   425
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   426
    else {                    // If 8-bit displacement, mode 0x1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   427
      if ((displace >= -128) && (displace <= 127)
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13485
diff changeset
   428
          && (disp_reloc == relocInfo::none) ) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   429
        emit_rm(cbuf, 0x1, reg_encoding, base);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   430
        emit_d8(cbuf, displace);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   431
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   432
      else {                  // If 32-bit displacement
489c9b5090e2 Initial load
duke
parents:
diff changeset
   433
        if (base == -1) { // Special flag for absolute address
489c9b5090e2 Initial load
duke
parents:
diff changeset
   434
          emit_rm(cbuf, 0x0, reg_encoding, 0x5);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   435
          // (manual lies; no SIB needed here)
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13485
diff changeset
   436
          if ( disp_reloc != relocInfo::none ) {
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13485
diff changeset
   437
            emit_d32_reloc(cbuf, displace, disp_reloc, 1);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   438
          } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   439
            emit_d32      (cbuf, displace);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   440
          }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   441
        }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   442
        else {                // Normal base + offset
489c9b5090e2 Initial load
duke
parents:
diff changeset
   443
          emit_rm(cbuf, 0x2, reg_encoding, base);
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13485
diff changeset
   444
          if ( disp_reloc != relocInfo::none ) {
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13485
diff changeset
   445
            emit_d32_reloc(cbuf, displace, disp_reloc, 1);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   446
          } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   447
            emit_d32      (cbuf, displace);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   448
          }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   449
        }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   450
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   451
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   452
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   453
  else {                      // Else, encode with the SIB byte
489c9b5090e2 Initial load
duke
parents:
diff changeset
   454
    // If no displacement, mode is 0x0; unless base is [EBP]
489c9b5090e2 Initial load
duke
parents:
diff changeset
   455
    if (displace == 0 && (base != EBP_enc)) {  // If no displacement
489c9b5090e2 Initial load
duke
parents:
diff changeset
   456
      emit_rm(cbuf, 0x0, reg_encoding, 0x4);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   457
      emit_rm(cbuf, scale, index, base);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   458
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   459
    else {                    // If 8-bit displacement, mode 0x1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   460
      if ((displace >= -128) && (displace <= 127)
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13485
diff changeset
   461
          && (disp_reloc == relocInfo::none) ) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   462
        emit_rm(cbuf, 0x1, reg_encoding, 0x4);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   463
        emit_rm(cbuf, scale, index, base);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   464
        emit_d8(cbuf, displace);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   465
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   466
      else {                  // If 32-bit displacement
489c9b5090e2 Initial load
duke
parents:
diff changeset
   467
        if (base == 0x04 ) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   468
          emit_rm(cbuf, 0x2, reg_encoding, 0x4);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   469
          emit_rm(cbuf, scale, index, 0x04);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   470
        } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   471
          emit_rm(cbuf, 0x2, reg_encoding, 0x4);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   472
          emit_rm(cbuf, scale, index, base);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   473
        }
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13485
diff changeset
   474
        if ( disp_reloc != relocInfo::none ) {
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13485
diff changeset
   475
          emit_d32_reloc(cbuf, displace, disp_reloc, 1);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   476
        } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   477
          emit_d32      (cbuf, displace);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   478
        }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   479
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   480
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   481
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   482
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   483
489c9b5090e2 Initial load
duke
parents:
diff changeset
   484
489c9b5090e2 Initial load
duke
parents:
diff changeset
   485
void encode_Copy( CodeBuffer &cbuf, int dst_encoding, int src_encoding ) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   486
  if( dst_encoding == src_encoding ) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   487
    // reg-reg copy, use an empty encoding
489c9b5090e2 Initial load
duke
parents:
diff changeset
   488
  } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   489
    emit_opcode( cbuf, 0x8B );
489c9b5090e2 Initial load
duke
parents:
diff changeset
   490
    emit_rm(cbuf, 0x3, dst_encoding, src_encoding );
489c9b5090e2 Initial load
duke
parents:
diff changeset
   491
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   492
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   493
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   494
void emit_cmpfp_fixup(MacroAssembler& _masm) {
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   495
  Label exit;
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   496
  __ jccb(Assembler::noParity, exit);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   497
  __ pushf();
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   498
  //
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   499
  // comiss/ucomiss instructions set ZF,PF,CF flags and
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   500
  // zero OF,AF,SF for NaN values.
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   501
  // Fixup flags by zeroing ZF,PF so that compare of NaN
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   502
  // values returns 'less than' result (CF is set).
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   503
  // Leave the rest of flags unchanged.
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   504
  //
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   505
  //    7 6 5 4 3 2 1 0
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   506
  //   |S|Z|r|A|r|P|r|C|  (r - reserved bit)
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   507
  //    0 0 1 0 1 0 1 1   (0x2B)
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   508
  //
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   509
  __ andl(Address(rsp, 0), 0xffffff2b);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   510
  __ popf();
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   511
  __ bind(exit);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   512
}
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   513
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   514
void emit_cmpfp3(MacroAssembler& _masm, Register dst) {
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   515
  Label done;
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   516
  __ movl(dst, -1);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   517
  __ jcc(Assembler::parity, done);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   518
  __ jcc(Assembler::below, done);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   519
  __ setb(Assembler::notEqual, dst);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   520
  __ movzbl(dst, dst);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   521
  __ bind(done);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   522
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   523
489c9b5090e2 Initial load
duke
parents:
diff changeset
   524
489c9b5090e2 Initial load
duke
parents:
diff changeset
   525
//=============================================================================
7433
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
   526
const RegMask& MachConstantBaseNode::_out_RegMask = RegMask::Empty;
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
   527
11190
d561d41f241a 7003454: order constants in constant table by number of references in code
twisti
parents: 10971
diff changeset
   528
int Compile::ConstantTable::calculate_table_base_offset() const {
d561d41f241a 7003454: order constants in constant table by number of references in code
twisti
parents: 10971
diff changeset
   529
  return 0;  // absolute addressing, no offset
d561d41f241a 7003454: order constants in constant table by number of references in code
twisti
parents: 10971
diff changeset
   530
}
d561d41f241a 7003454: order constants in constant table by number of references in code
twisti
parents: 10971
diff changeset
   531
22844
90f76a40ed8a 8003854: PPC64 (part 115): Introduce PostallocExpand that expands nodes after register allocation
goetz
parents: 22838
diff changeset
   532
bool MachConstantBaseNode::requires_postalloc_expand() const { return false; }
90f76a40ed8a 8003854: PPC64 (part 115): Introduce PostallocExpand that expands nodes after register allocation
goetz
parents: 22838
diff changeset
   533
void MachConstantBaseNode::postalloc_expand(GrowableArray <Node *> *nodes, PhaseRegAlloc *ra_) {
90f76a40ed8a 8003854: PPC64 (part 115): Introduce PostallocExpand that expands nodes after register allocation
goetz
parents: 22838
diff changeset
   534
  ShouldNotReachHere();
90f76a40ed8a 8003854: PPC64 (part 115): Introduce PostallocExpand that expands nodes after register allocation
goetz
parents: 22838
diff changeset
   535
}
90f76a40ed8a 8003854: PPC64 (part 115): Introduce PostallocExpand that expands nodes after register allocation
goetz
parents: 22838
diff changeset
   536
7433
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
   537
void MachConstantBaseNode::emit(CodeBuffer& cbuf, PhaseRegAlloc* ra_) const {
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
   538
  // Empty encoding
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
   539
}
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
   540
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
   541
uint MachConstantBaseNode::size(PhaseRegAlloc* ra_) const {
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
   542
  return 0;
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
   543
}
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
   544
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
   545
#ifndef PRODUCT
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
   546
void MachConstantBaseNode::format(PhaseRegAlloc* ra_, outputStream* st) const {
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
   547
  st->print("# MachConstantBaseNode (empty encoding)");
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
   548
}
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
   549
#endif
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
   550
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
   551
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
   552
//=============================================================================
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   553
#ifndef PRODUCT
11791
3be8cae67887 7125136: SIGILL on linux amd64 in gc/ArrayJuggle/Juggle29
kvn
parents: 11445
diff changeset
   554
void MachPrologNode::format(PhaseRegAlloc* ra_, outputStream* st) const {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   555
  Compile* C = ra_->C;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   556
24018
77b156916bab 8032410: compiler/uncommontrap/TestStackBangRbp.java times out on Solaris-Sparc V9
roland
parents: 23498
diff changeset
   557
  int framesize = C->frame_size_in_bytes();
77b156916bab 8032410: compiler/uncommontrap/TestStackBangRbp.java times out on Solaris-Sparc V9
roland
parents: 23498
diff changeset
   558
  int bangsize = C->bang_size_in_bytes();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   559
  assert((framesize & (StackAlignmentInBytes-1)) == 0, "frame size not aligned");
11791
3be8cae67887 7125136: SIGILL on linux amd64 in gc/ArrayJuggle/Juggle29
kvn
parents: 11445
diff changeset
   560
  // Remove wordSize for return addr which is already pushed.
3be8cae67887 7125136: SIGILL on linux amd64 in gc/ArrayJuggle/Juggle29
kvn
parents: 11445
diff changeset
   561
  framesize -= wordSize;
3be8cae67887 7125136: SIGILL on linux amd64 in gc/ArrayJuggle/Juggle29
kvn
parents: 11445
diff changeset
   562
24018
77b156916bab 8032410: compiler/uncommontrap/TestStackBangRbp.java times out on Solaris-Sparc V9
roland
parents: 23498
diff changeset
   563
  if (C->need_stack_bang(bangsize)) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   564
    framesize -= wordSize;
24018
77b156916bab 8032410: compiler/uncommontrap/TestStackBangRbp.java times out on Solaris-Sparc V9
roland
parents: 23498
diff changeset
   565
    st->print("# stack bang (%d bytes)", bangsize);
11791
3be8cae67887 7125136: SIGILL on linux amd64 in gc/ArrayJuggle/Juggle29
kvn
parents: 11445
diff changeset
   566
    st->print("\n\t");
3be8cae67887 7125136: SIGILL on linux amd64 in gc/ArrayJuggle/Juggle29
kvn
parents: 11445
diff changeset
   567
    st->print("PUSH   EBP\t# Save EBP");
30305
b92a97e1e9cb 8068945: Use RBP register as proper frame pointer in JIT compiled code on x86
zmajo
parents: 28954
diff changeset
   568
    if (PreserveFramePointer) {
b92a97e1e9cb 8068945: Use RBP register as proper frame pointer in JIT compiled code on x86
zmajo
parents: 28954
diff changeset
   569
      st->print("\n\t");
b92a97e1e9cb 8068945: Use RBP register as proper frame pointer in JIT compiled code on x86
zmajo
parents: 28954
diff changeset
   570
      st->print("MOV    EBP, ESP\t# Save the caller's SP into EBP");
b92a97e1e9cb 8068945: Use RBP register as proper frame pointer in JIT compiled code on x86
zmajo
parents: 28954
diff changeset
   571
    }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   572
    if (framesize) {
11791
3be8cae67887 7125136: SIGILL on linux amd64 in gc/ArrayJuggle/Juggle29
kvn
parents: 11445
diff changeset
   573
      st->print("\n\t");
3be8cae67887 7125136: SIGILL on linux amd64 in gc/ArrayJuggle/Juggle29
kvn
parents: 11445
diff changeset
   574
      st->print("SUB    ESP, #%d\t# Create frame",framesize);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   575
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   576
  } else {
11791
3be8cae67887 7125136: SIGILL on linux amd64 in gc/ArrayJuggle/Juggle29
kvn
parents: 11445
diff changeset
   577
    st->print("SUB    ESP, #%d\t# Create frame",framesize);
3be8cae67887 7125136: SIGILL on linux amd64 in gc/ArrayJuggle/Juggle29
kvn
parents: 11445
diff changeset
   578
    st->print("\n\t");
3be8cae67887 7125136: SIGILL on linux amd64 in gc/ArrayJuggle/Juggle29
kvn
parents: 11445
diff changeset
   579
    framesize -= wordSize;
3be8cae67887 7125136: SIGILL on linux amd64 in gc/ArrayJuggle/Juggle29
kvn
parents: 11445
diff changeset
   580
    st->print("MOV    [ESP + #%d], EBP\t# Save EBP",framesize);
30305
b92a97e1e9cb 8068945: Use RBP register as proper frame pointer in JIT compiled code on x86
zmajo
parents: 28954
diff changeset
   581
    if (PreserveFramePointer) {
b92a97e1e9cb 8068945: Use RBP register as proper frame pointer in JIT compiled code on x86
zmajo
parents: 28954
diff changeset
   582
      st->print("\n\t");
33188
6d91a3077eca 8080650: Enable stubs to use frame pointers correctly
zmajo
parents: 33089
diff changeset
   583
      st->print("MOV    EBP, ESP\t# Save the caller's SP into EBP");
6d91a3077eca 8080650: Enable stubs to use frame pointers correctly
zmajo
parents: 33089
diff changeset
   584
      if (framesize > 0) {
6d91a3077eca 8080650: Enable stubs to use frame pointers correctly
zmajo
parents: 33089
diff changeset
   585
        st->print("\n\t");
6d91a3077eca 8080650: Enable stubs to use frame pointers correctly
zmajo
parents: 33089
diff changeset
   586
        st->print("ADD    EBP, #%d", framesize);
6d91a3077eca 8080650: Enable stubs to use frame pointers correctly
zmajo
parents: 33089
diff changeset
   587
      }
30305
b92a97e1e9cb 8068945: Use RBP register as proper frame pointer in JIT compiled code on x86
zmajo
parents: 28954
diff changeset
   588
    }
11791
3be8cae67887 7125136: SIGILL on linux amd64 in gc/ArrayJuggle/Juggle29
kvn
parents: 11445
diff changeset
   589
  }
3be8cae67887 7125136: SIGILL on linux amd64 in gc/ArrayJuggle/Juggle29
kvn
parents: 11445
diff changeset
   590
3be8cae67887 7125136: SIGILL on linux amd64 in gc/ArrayJuggle/Juggle29
kvn
parents: 11445
diff changeset
   591
  if (VerifyStackAtCalls) {
3be8cae67887 7125136: SIGILL on linux amd64 in gc/ArrayJuggle/Juggle29
kvn
parents: 11445
diff changeset
   592
    st->print("\n\t");
3be8cae67887 7125136: SIGILL on linux amd64 in gc/ArrayJuggle/Juggle29
kvn
parents: 11445
diff changeset
   593
    framesize -= wordSize;
3be8cae67887 7125136: SIGILL on linux amd64 in gc/ArrayJuggle/Juggle29
kvn
parents: 11445
diff changeset
   594
    st->print("MOV    [ESP + #%d], 0xBADB100D\t# Majik cookie for stack depth check",framesize);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   595
  }
11791
3be8cae67887 7125136: SIGILL on linux amd64 in gc/ArrayJuggle/Juggle29
kvn
parents: 11445
diff changeset
   596
3be8cae67887 7125136: SIGILL on linux amd64 in gc/ArrayJuggle/Juggle29
kvn
parents: 11445
diff changeset
   597
  if( C->in_24_bit_fp_mode() ) {
3be8cae67887 7125136: SIGILL on linux amd64 in gc/ArrayJuggle/Juggle29
kvn
parents: 11445
diff changeset
   598
    st->print("\n\t");
3be8cae67887 7125136: SIGILL on linux amd64 in gc/ArrayJuggle/Juggle29
kvn
parents: 11445
diff changeset
   599
    st->print("FLDCW  \t# load 24 bit fpu control word");
3be8cae67887 7125136: SIGILL on linux amd64 in gc/ArrayJuggle/Juggle29
kvn
parents: 11445
diff changeset
   600
  }
3be8cae67887 7125136: SIGILL on linux amd64 in gc/ArrayJuggle/Juggle29
kvn
parents: 11445
diff changeset
   601
  if (UseSSE >= 2 && VerifyFPU) {
3be8cae67887 7125136: SIGILL on linux amd64 in gc/ArrayJuggle/Juggle29
kvn
parents: 11445
diff changeset
   602
    st->print("\n\t");
3be8cae67887 7125136: SIGILL on linux amd64 in gc/ArrayJuggle/Juggle29
kvn
parents: 11445
diff changeset
   603
    st->print("# verify FPU stack (must be clean on entry)");
3be8cae67887 7125136: SIGILL on linux amd64 in gc/ArrayJuggle/Juggle29
kvn
parents: 11445
diff changeset
   604
  }
3be8cae67887 7125136: SIGILL on linux amd64 in gc/ArrayJuggle/Juggle29
kvn
parents: 11445
diff changeset
   605
3be8cae67887 7125136: SIGILL on linux amd64 in gc/ArrayJuggle/Juggle29
kvn
parents: 11445
diff changeset
   606
#ifdef ASSERT
3be8cae67887 7125136: SIGILL on linux amd64 in gc/ArrayJuggle/Juggle29
kvn
parents: 11445
diff changeset
   607
  if (VerifyStackAtCalls) {
3be8cae67887 7125136: SIGILL on linux amd64 in gc/ArrayJuggle/Juggle29
kvn
parents: 11445
diff changeset
   608
    st->print("\n\t");
3be8cae67887 7125136: SIGILL on linux amd64 in gc/ArrayJuggle/Juggle29
kvn
parents: 11445
diff changeset
   609
    st->print("# stack alignment check");
3be8cae67887 7125136: SIGILL on linux amd64 in gc/ArrayJuggle/Juggle29
kvn
parents: 11445
diff changeset
   610
  }
3be8cae67887 7125136: SIGILL on linux amd64 in gc/ArrayJuggle/Juggle29
kvn
parents: 11445
diff changeset
   611
#endif
3be8cae67887 7125136: SIGILL on linux amd64 in gc/ArrayJuggle/Juggle29
kvn
parents: 11445
diff changeset
   612
  st->cr();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   613
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   614
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
   615
489c9b5090e2 Initial load
duke
parents:
diff changeset
   616
489c9b5090e2 Initial load
duke
parents:
diff changeset
   617
void MachPrologNode::emit(CodeBuffer &cbuf, PhaseRegAlloc *ra_) const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   618
  Compile* C = ra_->C;
11791
3be8cae67887 7125136: SIGILL on linux amd64 in gc/ArrayJuggle/Juggle29
kvn
parents: 11445
diff changeset
   619
  MacroAssembler _masm(&cbuf);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   620
24018
77b156916bab 8032410: compiler/uncommontrap/TestStackBangRbp.java times out on Solaris-Sparc V9
roland
parents: 23498
diff changeset
   621
  int framesize = C->frame_size_in_bytes();
77b156916bab 8032410: compiler/uncommontrap/TestStackBangRbp.java times out on Solaris-Sparc V9
roland
parents: 23498
diff changeset
   622
  int bangsize = C->bang_size_in_bytes();
77b156916bab 8032410: compiler/uncommontrap/TestStackBangRbp.java times out on Solaris-Sparc V9
roland
parents: 23498
diff changeset
   623
77b156916bab 8032410: compiler/uncommontrap/TestStackBangRbp.java times out on Solaris-Sparc V9
roland
parents: 23498
diff changeset
   624
  __ verified_entry(framesize, C->need_stack_bang(bangsize)?bangsize:0, C->in_24_bit_fp_mode());
11791
3be8cae67887 7125136: SIGILL on linux amd64 in gc/ArrayJuggle/Juggle29
kvn
parents: 11445
diff changeset
   625
6418
6671edbd230e 6978355: renaming for 6961697
twisti
parents: 6272
diff changeset
   626
  C->set_frame_complete(cbuf.insts_size());
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   627
11190
d561d41f241a 7003454: order constants in constant table by number of references in code
twisti
parents: 10971
diff changeset
   628
  if (C->has_mach_constant_base_node()) {
d561d41f241a 7003454: order constants in constant table by number of references in code
twisti
parents: 10971
diff changeset
   629
    // NOTE: We set the table base offset here because users might be
d561d41f241a 7003454: order constants in constant table by number of references in code
twisti
parents: 10971
diff changeset
   630
    // emitted before MachConstantBaseNode.
d561d41f241a 7003454: order constants in constant table by number of references in code
twisti
parents: 10971
diff changeset
   631
    Compile::ConstantTable& constant_table = C->constant_table();
d561d41f241a 7003454: order constants in constant table by number of references in code
twisti
parents: 10971
diff changeset
   632
    constant_table.set_table_base_offset(constant_table.calculate_table_base_offset());
d561d41f241a 7003454: order constants in constant table by number of references in code
twisti
parents: 10971
diff changeset
   633
  }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   634
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   635
489c9b5090e2 Initial load
duke
parents:
diff changeset
   636
uint MachPrologNode::size(PhaseRegAlloc *ra_) const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   637
  return MachNode::size(ra_); // too many variables; just compute it the hard way
489c9b5090e2 Initial load
duke
parents:
diff changeset
   638
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   639
489c9b5090e2 Initial load
duke
parents:
diff changeset
   640
int MachPrologNode::reloc() const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   641
  return 0; // a large enough number
489c9b5090e2 Initial load
duke
parents:
diff changeset
   642
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   643
489c9b5090e2 Initial load
duke
parents:
diff changeset
   644
//=============================================================================
489c9b5090e2 Initial load
duke
parents:
diff changeset
   645
#ifndef PRODUCT
489c9b5090e2 Initial load
duke
parents:
diff changeset
   646
void MachEpilogNode::format( PhaseRegAlloc *ra_, outputStream* st ) const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   647
  Compile *C = ra_->C;
24018
77b156916bab 8032410: compiler/uncommontrap/TestStackBangRbp.java times out on Solaris-Sparc V9
roland
parents: 23498
diff changeset
   648
  int framesize = C->frame_size_in_bytes();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   649
  assert((framesize & (StackAlignmentInBytes-1)) == 0, "frame size not aligned");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   650
  // Remove two words for return addr and rbp,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   651
  framesize -= 2*wordSize;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   652
16624
9dbd4b210bf9 8011102: Clear AVX registers after return from JNI call
kvn
parents: 15242
diff changeset
   653
  if (C->max_vector_size() > 16) {
9dbd4b210bf9 8011102: Clear AVX registers after return from JNI call
kvn
parents: 15242
diff changeset
   654
    st->print("VZEROUPPER");
9dbd4b210bf9 8011102: Clear AVX registers after return from JNI call
kvn
parents: 15242
diff changeset
   655
    st->cr(); st->print("\t");
9dbd4b210bf9 8011102: Clear AVX registers after return from JNI call
kvn
parents: 15242
diff changeset
   656
  }
9dbd4b210bf9 8011102: Clear AVX registers after return from JNI call
kvn
parents: 15242
diff changeset
   657
  if (C->in_24_bit_fp_mode()) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   658
    st->print("FLDCW  standard control word");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   659
    st->cr(); st->print("\t");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   660
  }
16624
9dbd4b210bf9 8011102: Clear AVX registers after return from JNI call
kvn
parents: 15242
diff changeset
   661
  if (framesize) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   662
    st->print("ADD    ESP,%d\t# Destroy frame",framesize);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   663
    st->cr(); st->print("\t");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   664
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   665
  st->print_cr("POPL   EBP"); st->print("\t");
16624
9dbd4b210bf9 8011102: Clear AVX registers after return from JNI call
kvn
parents: 15242
diff changeset
   666
  if (do_polling() && C->is_method_compilation()) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   667
    st->print("TEST   PollPage,EAX\t! Poll Safepoint");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   668
    st->cr(); st->print("\t");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   669
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   670
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   671
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
   672
489c9b5090e2 Initial load
duke
parents:
diff changeset
   673
void MachEpilogNode::emit(CodeBuffer &cbuf, PhaseRegAlloc *ra_) const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   674
  Compile *C = ra_->C;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   675
16624
9dbd4b210bf9 8011102: Clear AVX registers after return from JNI call
kvn
parents: 15242
diff changeset
   676
  if (C->max_vector_size() > 16) {
9dbd4b210bf9 8011102: Clear AVX registers after return from JNI call
kvn
parents: 15242
diff changeset
   677
    // Clear upper bits of YMM registers when current compiled code uses
9dbd4b210bf9 8011102: Clear AVX registers after return from JNI call
kvn
parents: 15242
diff changeset
   678
    // wide vectors to avoid AVX <-> SSE transition penalty during call.
9dbd4b210bf9 8011102: Clear AVX registers after return from JNI call
kvn
parents: 15242
diff changeset
   679
    MacroAssembler masm(&cbuf);
9dbd4b210bf9 8011102: Clear AVX registers after return from JNI call
kvn
parents: 15242
diff changeset
   680
    masm.vzeroupper();
9dbd4b210bf9 8011102: Clear AVX registers after return from JNI call
kvn
parents: 15242
diff changeset
   681
  }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   682
  // If method set FPU control word, restore to standard control word
16624
9dbd4b210bf9 8011102: Clear AVX registers after return from JNI call
kvn
parents: 15242
diff changeset
   683
  if (C->in_24_bit_fp_mode()) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   684
    MacroAssembler masm(&cbuf);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   685
    masm.fldcw(ExternalAddress(StubRoutines::addr_fpu_cntrl_wrd_std()));
489c9b5090e2 Initial load
duke
parents:
diff changeset
   686
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   687
24018
77b156916bab 8032410: compiler/uncommontrap/TestStackBangRbp.java times out on Solaris-Sparc V9
roland
parents: 23498
diff changeset
   688
  int framesize = C->frame_size_in_bytes();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   689
  assert((framesize & (StackAlignmentInBytes-1)) == 0, "frame size not aligned");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   690
  // Remove two words for return addr and rbp,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   691
  framesize -= 2*wordSize;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   692
489c9b5090e2 Initial load
duke
parents:
diff changeset
   693
  // Note that VerifyStackAtCalls' Majik cookie does not change the frame size popped here
489c9b5090e2 Initial load
duke
parents:
diff changeset
   694
16624
9dbd4b210bf9 8011102: Clear AVX registers after return from JNI call
kvn
parents: 15242
diff changeset
   695
  if (framesize >= 128) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   696
    emit_opcode(cbuf, 0x81); // add  SP, #framesize
489c9b5090e2 Initial load
duke
parents:
diff changeset
   697
    emit_rm(cbuf, 0x3, 0x00, ESP_enc);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   698
    emit_d32(cbuf, framesize);
16624
9dbd4b210bf9 8011102: Clear AVX registers after return from JNI call
kvn
parents: 15242
diff changeset
   699
  } else if (framesize) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   700
    emit_opcode(cbuf, 0x83); // add  SP, #framesize
489c9b5090e2 Initial load
duke
parents:
diff changeset
   701
    emit_rm(cbuf, 0x3, 0x00, ESP_enc);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   702
    emit_d8(cbuf, framesize);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   703
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   704
489c9b5090e2 Initial load
duke
parents:
diff changeset
   705
  emit_opcode(cbuf, 0x58 | EBP_enc);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   706
16624
9dbd4b210bf9 8011102: Clear AVX registers after return from JNI call
kvn
parents: 15242
diff changeset
   707
  if (do_polling() && C->is_method_compilation()) {
6418
6671edbd230e 6978355: renaming for 6961697
twisti
parents: 6272
diff changeset
   708
    cbuf.relocate(cbuf.insts_end(), relocInfo::poll_return_type, 0);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   709
    emit_opcode(cbuf,0x85);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   710
    emit_rm(cbuf, 0x0, EAX_enc, 0x5); // EAX
489c9b5090e2 Initial load
duke
parents:
diff changeset
   711
    emit_d32(cbuf, (intptr_t)os::get_polling_page());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   712
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   713
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   714
489c9b5090e2 Initial load
duke
parents:
diff changeset
   715
uint MachEpilogNode::size(PhaseRegAlloc *ra_) const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   716
  Compile *C = ra_->C;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   717
  // If method set FPU control word, restore to standard control word
489c9b5090e2 Initial load
duke
parents:
diff changeset
   718
  int size = C->in_24_bit_fp_mode() ? 6 : 0;
16624
9dbd4b210bf9 8011102: Clear AVX registers after return from JNI call
kvn
parents: 15242
diff changeset
   719
  if (C->max_vector_size() > 16) size += 3; // vzeroupper
9dbd4b210bf9 8011102: Clear AVX registers after return from JNI call
kvn
parents: 15242
diff changeset
   720
  if (do_polling() && C->is_method_compilation()) size += 6;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   721
24018
77b156916bab 8032410: compiler/uncommontrap/TestStackBangRbp.java times out on Solaris-Sparc V9
roland
parents: 23498
diff changeset
   722
  int framesize = C->frame_size_in_bytes();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   723
  assert((framesize & (StackAlignmentInBytes-1)) == 0, "frame size not aligned");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   724
  // Remove two words for return addr and rbp,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   725
  framesize -= 2*wordSize;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   726
489c9b5090e2 Initial load
duke
parents:
diff changeset
   727
  size++; // popl rbp,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   728
16624
9dbd4b210bf9 8011102: Clear AVX registers after return from JNI call
kvn
parents: 15242
diff changeset
   729
  if (framesize >= 128) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   730
    size += 6;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   731
  } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   732
    size += framesize ? 3 : 0;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   733
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   734
  return size;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   735
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   736
489c9b5090e2 Initial load
duke
parents:
diff changeset
   737
int MachEpilogNode::reloc() const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   738
  return 0; // a large enough number
489c9b5090e2 Initial load
duke
parents:
diff changeset
   739
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   740
489c9b5090e2 Initial load
duke
parents:
diff changeset
   741
const Pipeline * MachEpilogNode::pipeline() const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   742
  return MachNode::pipeline_class();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   743
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   744
489c9b5090e2 Initial load
duke
parents:
diff changeset
   745
int MachEpilogNode::safepoint_offset() const { return 0; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   746
489c9b5090e2 Initial load
duke
parents:
diff changeset
   747
//=============================================================================
489c9b5090e2 Initial load
duke
parents:
diff changeset
   748
489c9b5090e2 Initial load
duke
parents:
diff changeset
   749
enum RC { rc_bad, rc_int, rc_float, rc_xmm, rc_stack };
489c9b5090e2 Initial load
duke
parents:
diff changeset
   750
static enum RC rc_class( OptoReg::Name reg ) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   751
489c9b5090e2 Initial load
duke
parents:
diff changeset
   752
  if( !OptoReg::is_valid(reg)  ) return rc_bad;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   753
  if (OptoReg::is_stack(reg)) return rc_stack;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   754
489c9b5090e2 Initial load
duke
parents:
diff changeset
   755
  VMReg r = OptoReg::as_VMReg(reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   756
  if (r->is_Register()) return rc_int;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   757
  if (r->is_FloatRegister()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   758
    assert(UseSSE < 2, "shouldn't be used in SSE2+ mode");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   759
    return rc_float;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   760
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   761
  assert(r->is_XMMRegister(), "must be");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   762
  return rc_xmm;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   763
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   764
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
   765
static int impl_helper( CodeBuffer *cbuf, bool do_size, bool is_load, int offset, int reg,
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
   766
                        int opcode, const char *op_str, int size, outputStream* st ) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   767
  if( cbuf ) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   768
    emit_opcode  (*cbuf, opcode );
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13485
diff changeset
   769
    encode_RegMem(*cbuf, Matcher::_regEncode[reg], ESP_enc, 0x4, 0, offset, relocInfo::none);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   770
#ifndef PRODUCT
489c9b5090e2 Initial load
duke
parents:
diff changeset
   771
  } else if( !do_size ) {
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
   772
    if( size != 0 ) st->print("\n\t");
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   773
    if( opcode == 0x8B || opcode == 0x89 ) { // MOV
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
   774
      if( is_load ) st->print("%s   %s,[ESP + #%d]",op_str,Matcher::regName[reg],offset);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
   775
      else          st->print("%s   [ESP + #%d],%s",op_str,offset,Matcher::regName[reg]);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   776
    } else { // FLD, FST, PUSH, POP
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
   777
      st->print("%s [ESP + #%d]",op_str,offset);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   778
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   779
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
   780
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   781
  int offset_size = (offset == 0) ? 0 : ((offset <= 127) ? 1 : 4);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   782
  return size+3+offset_size;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   783
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   784
489c9b5090e2 Initial load
duke
parents:
diff changeset
   785
// Helper for XMM registers.  Extra opcode bits, limited syntax.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   786
static int impl_x_helper( CodeBuffer *cbuf, bool do_size, bool is_load,
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
   787
                         int offset, int reg_lo, int reg_hi, int size, outputStream* st ) {
30624
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
   788
  int in_size_in_bits = Assembler::EVEX_32bit;
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
   789
  int evex_encoding = 0;
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
   790
  if (reg_lo+1 == reg_hi) {
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
   791
    in_size_in_bits = Assembler::EVEX_64bit;
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
   792
    evex_encoding = Assembler::VEX_W;
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
   793
  }
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   794
  if (cbuf) {
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   795
    MacroAssembler _masm(cbuf);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   796
    if (reg_lo+1 == reg_hi) { // double move?
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   797
      if (is_load) {
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   798
        __ movdbl(as_XMMRegister(Matcher::_regEncode[reg_lo]), Address(rsp, offset));
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   799
      } else {
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   800
        __ movdbl(Address(rsp, offset), as_XMMRegister(Matcher::_regEncode[reg_lo]));
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   801
      }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   802
    } else {
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   803
      if (is_load) {
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   804
        __ movflt(as_XMMRegister(Matcher::_regEncode[reg_lo]), Address(rsp, offset));
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   805
      } else {
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   806
        __ movflt(Address(rsp, offset), as_XMMRegister(Matcher::_regEncode[reg_lo]));
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   807
      }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   808
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   809
#ifndef PRODUCT
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   810
  } else if (!do_size) {
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   811
    if (size != 0) st->print("\n\t");
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   812
    if (reg_lo+1 == reg_hi) { // double move?
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   813
      if (is_load) st->print("%s %s,[ESP + #%d]",
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   814
                              UseXmmLoadAndClearUpper ? "MOVSD " : "MOVLPD",
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   815
                              Matcher::regName[reg_lo], offset);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   816
      else         st->print("MOVSD  [ESP + #%d],%s",
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   817
                              offset, Matcher::regName[reg_lo]);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   818
    } else {
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   819
      if (is_load) st->print("MOVSS  %s,[ESP + #%d]",
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   820
                              Matcher::regName[reg_lo], offset);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   821
      else         st->print("MOVSS  [ESP + #%d],%s",
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   822
                              offset, Matcher::regName[reg_lo]);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   823
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   824
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
   825
  }
30624
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
   826
  bool is_single_byte = false;
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
   827
  if ((UseAVX > 2) && (offset != 0)) {
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
   828
    is_single_byte = Assembler::query_compressed_disp_byte(offset, true, 0, Assembler::EVEX_T1S, in_size_in_bits, evex_encoding);
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
   829
  }
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
   830
  int offset_size = 0;
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
   831
  if (UseAVX > 2 ) {
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
   832
    offset_size = (offset == 0) ? 0 : ((is_single_byte) ? 1 : 4);
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
   833
  } else {
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
   834
    offset_size = (offset == 0) ? 0 : ((offset <= 127) ? 1 : 4);
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
   835
  }
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
   836
  size += (UseAVX > 2) ? 2 : 0; // Need an additional two bytes for EVEX
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
   837
  // VEX_2bytes prefix is used if UseAVX > 0, so it takes the same 2 bytes as SIMD prefix.
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   838
  return size+5+offset_size;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   839
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   840
489c9b5090e2 Initial load
duke
parents:
diff changeset
   841
489c9b5090e2 Initial load
duke
parents:
diff changeset
   842
static int impl_movx_helper( CodeBuffer *cbuf, bool do_size, int src_lo, int dst_lo,
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
   843
                            int src_hi, int dst_hi, int size, outputStream* st ) {
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   844
  if (cbuf) {
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   845
    MacroAssembler _masm(cbuf);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   846
    if (src_lo+1 == src_hi && dst_lo+1 == dst_hi) { // double move?
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   847
      __ movdbl(as_XMMRegister(Matcher::_regEncode[dst_lo]),
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   848
                as_XMMRegister(Matcher::_regEncode[src_lo]));
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   849
    } else {
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   850
      __ movflt(as_XMMRegister(Matcher::_regEncode[dst_lo]),
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   851
                as_XMMRegister(Matcher::_regEncode[src_lo]));
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   852
    }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   853
#ifndef PRODUCT
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   854
  } else if (!do_size) {
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   855
    if (size != 0) st->print("\n\t");
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   856
    if (UseXmmRegToRegMoveAll) {//Use movaps,movapd to move between xmm registers
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   857
      if (src_lo+1 == src_hi && dst_lo+1 == dst_hi) { // double move?
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
   858
        st->print("MOVAPD %s,%s",Matcher::regName[dst_lo],Matcher::regName[src_lo]);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   859
      } else {
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
   860
        st->print("MOVAPS %s,%s",Matcher::regName[dst_lo],Matcher::regName[src_lo]);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   861
      }
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   862
    } else {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   863
      if( src_lo+1 == src_hi && dst_lo+1 == dst_hi ) { // double move?
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
   864
        st->print("MOVSD  %s,%s",Matcher::regName[dst_lo],Matcher::regName[src_lo]);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   865
      } else {
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
   866
        st->print("MOVSS  %s,%s",Matcher::regName[dst_lo],Matcher::regName[src_lo]);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   867
      }
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   868
    }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   869
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
   870
  }
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
   871
  // VEX_2bytes prefix is used if UseAVX > 0, and it takes the same 2 bytes as SIMD prefix.
30624
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
   872
  // Only MOVAPS SSE prefix uses 1 byte.  EVEX uses an additional 2 bytes.
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
   873
  int sz = (UseAVX > 2) ? 6 : 4;
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   874
  if (!(src_lo+1 == src_hi && dst_lo+1 == dst_hi) &&
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   875
      UseXmmRegToRegMoveAll && (UseAVX == 0)) sz = 3;
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   876
  return size + sz;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   877
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   878
6272
94a20ad0e9de 6978249: spill between cpu and fpu registers when those moves are fast
never
parents: 5702
diff changeset
   879
static int impl_movgpr2x_helper( CodeBuffer *cbuf, bool do_size, int src_lo, int dst_lo,
94a20ad0e9de 6978249: spill between cpu and fpu registers when those moves are fast
never
parents: 5702
diff changeset
   880
                            int src_hi, int dst_hi, int size, outputStream* st ) {
94a20ad0e9de 6978249: spill between cpu and fpu registers when those moves are fast
never
parents: 5702
diff changeset
   881
  // 32-bit
94a20ad0e9de 6978249: spill between cpu and fpu registers when those moves are fast
never
parents: 5702
diff changeset
   882
  if (cbuf) {
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   883
    MacroAssembler _masm(cbuf);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   884
    __ movdl(as_XMMRegister(Matcher::_regEncode[dst_lo]),
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   885
             as_Register(Matcher::_regEncode[src_lo]));
6272
94a20ad0e9de 6978249: spill between cpu and fpu registers when those moves are fast
never
parents: 5702
diff changeset
   886
#ifndef PRODUCT
94a20ad0e9de 6978249: spill between cpu and fpu registers when those moves are fast
never
parents: 5702
diff changeset
   887
  } else if (!do_size) {
94a20ad0e9de 6978249: spill between cpu and fpu registers when those moves are fast
never
parents: 5702
diff changeset
   888
    st->print("movdl   %s, %s\t# spill", Matcher::regName[dst_lo], Matcher::regName[src_lo]);
94a20ad0e9de 6978249: spill between cpu and fpu registers when those moves are fast
never
parents: 5702
diff changeset
   889
#endif
94a20ad0e9de 6978249: spill between cpu and fpu registers when those moves are fast
never
parents: 5702
diff changeset
   890
  }
30624
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
   891
  return (UseAVX> 2) ? 6 : 4;
6272
94a20ad0e9de 6978249: spill between cpu and fpu registers when those moves are fast
never
parents: 5702
diff changeset
   892
}
94a20ad0e9de 6978249: spill between cpu and fpu registers when those moves are fast
never
parents: 5702
diff changeset
   893
94a20ad0e9de 6978249: spill between cpu and fpu registers when those moves are fast
never
parents: 5702
diff changeset
   894
94a20ad0e9de 6978249: spill between cpu and fpu registers when those moves are fast
never
parents: 5702
diff changeset
   895
static int impl_movx2gpr_helper( CodeBuffer *cbuf, bool do_size, int src_lo, int dst_lo,
94a20ad0e9de 6978249: spill between cpu and fpu registers when those moves are fast
never
parents: 5702
diff changeset
   896
                                 int src_hi, int dst_hi, int size, outputStream* st ) {
94a20ad0e9de 6978249: spill between cpu and fpu registers when those moves are fast
never
parents: 5702
diff changeset
   897
  // 32-bit
94a20ad0e9de 6978249: spill between cpu and fpu registers when those moves are fast
never
parents: 5702
diff changeset
   898
  if (cbuf) {
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   899
    MacroAssembler _masm(cbuf);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   900
    __ movdl(as_Register(Matcher::_regEncode[dst_lo]),
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
   901
             as_XMMRegister(Matcher::_regEncode[src_lo]));
6272
94a20ad0e9de 6978249: spill between cpu and fpu registers when those moves are fast
never
parents: 5702
diff changeset
   902
#ifndef PRODUCT
94a20ad0e9de 6978249: spill between cpu and fpu registers when those moves are fast
never
parents: 5702
diff changeset
   903
  } else if (!do_size) {
94a20ad0e9de 6978249: spill between cpu and fpu registers when those moves are fast
never
parents: 5702
diff changeset
   904
    st->print("movdl   %s, %s\t# spill", Matcher::regName[dst_lo], Matcher::regName[src_lo]);
94a20ad0e9de 6978249: spill between cpu and fpu registers when those moves are fast
never
parents: 5702
diff changeset
   905
#endif
94a20ad0e9de 6978249: spill between cpu and fpu registers when those moves are fast
never
parents: 5702
diff changeset
   906
  }
30624
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
   907
  return (UseAVX> 2) ? 6 : 4;
6272
94a20ad0e9de 6978249: spill between cpu and fpu registers when those moves are fast
never
parents: 5702
diff changeset
   908
}
94a20ad0e9de 6978249: spill between cpu and fpu registers when those moves are fast
never
parents: 5702
diff changeset
   909
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
   910
static int impl_mov_helper( CodeBuffer *cbuf, bool do_size, int src, int dst, int size, outputStream* st ) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   911
  if( cbuf ) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   912
    emit_opcode(*cbuf, 0x8B );
489c9b5090e2 Initial load
duke
parents:
diff changeset
   913
    emit_rm    (*cbuf, 0x3, Matcher::_regEncode[dst], Matcher::_regEncode[src] );
489c9b5090e2 Initial load
duke
parents:
diff changeset
   914
#ifndef PRODUCT
489c9b5090e2 Initial load
duke
parents:
diff changeset
   915
  } else if( !do_size ) {
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
   916
    if( size != 0 ) st->print("\n\t");
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
   917
    st->print("MOV    %s,%s",Matcher::regName[dst],Matcher::regName[src]);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   918
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
   919
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   920
  return size+2;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   921
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   922
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
   923
static int impl_fp_store_helper( CodeBuffer *cbuf, bool do_size, int src_lo, int src_hi, int dst_lo, int dst_hi,
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
   924
                                 int offset, int size, outputStream* st ) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   925
  if( src_lo != FPR1L_num ) {      // Move value to top of FP stack, if not already there
489c9b5090e2 Initial load
duke
parents:
diff changeset
   926
    if( cbuf ) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   927
      emit_opcode( *cbuf, 0xD9 );  // FLD (i.e., push it)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   928
      emit_d8( *cbuf, 0xC0-1+Matcher::_regEncode[src_lo] );
489c9b5090e2 Initial load
duke
parents:
diff changeset
   929
#ifndef PRODUCT
489c9b5090e2 Initial load
duke
parents:
diff changeset
   930
    } else if( !do_size ) {
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
   931
      if( size != 0 ) st->print("\n\t");
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
   932
      st->print("FLD    %s",Matcher::regName[src_lo]);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   933
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
   934
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   935
    size += 2;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   936
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   937
489c9b5090e2 Initial load
duke
parents:
diff changeset
   938
  int st_op = (src_lo != FPR1L_num) ? EBX_num /*store & pop*/ : EDX_num /*store no pop*/;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   939
  const char *op_str;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   940
  int op;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   941
  if( src_lo+1 == src_hi && dst_lo+1 == dst_hi ) { // double store?
489c9b5090e2 Initial load
duke
parents:
diff changeset
   942
    op_str = (src_lo != FPR1L_num) ? "FSTP_D" : "FST_D ";
489c9b5090e2 Initial load
duke
parents:
diff changeset
   943
    op = 0xDD;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   944
  } else {                   // 32-bit store
489c9b5090e2 Initial load
duke
parents:
diff changeset
   945
    op_str = (src_lo != FPR1L_num) ? "FSTP_S" : "FST_S ";
489c9b5090e2 Initial load
duke
parents:
diff changeset
   946
    op = 0xD9;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   947
    assert( !OptoReg::is_valid(src_hi) && !OptoReg::is_valid(dst_hi), "no non-adjacent float-stores" );
489c9b5090e2 Initial load
duke
parents:
diff changeset
   948
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   949
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
   950
  return impl_helper(cbuf,do_size,false,offset,st_op,op,op_str,size, st);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   951
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   952
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
   953
// Next two methods are shared by 32- and 64-bit VM. They are defined in x86.ad.
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
   954
static int vec_mov_helper(CodeBuffer *cbuf, bool do_size, int src_lo, int dst_lo,
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
   955
                          int src_hi, int dst_hi, uint ireg, outputStream* st);
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
   956
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
   957
static int vec_spill_helper(CodeBuffer *cbuf, bool do_size, bool is_load,
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
   958
                            int stack_offset, int reg, uint ireg, outputStream* st);
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
   959
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
   960
static int vec_stack_to_stack_helper(CodeBuffer *cbuf, bool do_size, int src_offset,
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
   961
                                     int dst_offset, uint ireg, outputStream* st) {
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
   962
  int calc_size = 0;
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
   963
  int src_offset_size = (src_offset == 0) ? 0 : ((src_offset < 0x80) ? 1 : 4);
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
   964
  int dst_offset_size = (dst_offset == 0) ? 0 : ((dst_offset < 0x80) ? 1 : 4);
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
   965
  switch (ireg) {
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
   966
  case Op_VecS:
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
   967
    calc_size = 3+src_offset_size + 3+dst_offset_size;
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
   968
    break;
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
   969
  case Op_VecD:
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
   970
    calc_size = 3+src_offset_size + 3+dst_offset_size;
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
   971
    src_offset += 4;
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
   972
    dst_offset += 4;
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
   973
    src_offset_size = (src_offset == 0) ? 0 : ((src_offset < 0x80) ? 1 : 4);
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
   974
    dst_offset_size = (dst_offset == 0) ? 0 : ((dst_offset < 0x80) ? 1 : 4);
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
   975
    calc_size += 3+src_offset_size + 3+dst_offset_size;
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
   976
    break;
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
   977
  case Op_VecX:
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
   978
  case Op_VecY:
30624
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
   979
  case Op_VecZ:
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
   980
    calc_size = 6 + 6 + 5+src_offset_size + 5+dst_offset_size;
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
   981
    break;
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
   982
  default:
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
   983
    ShouldNotReachHere();
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
   984
  }
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
   985
  if (cbuf) {
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
   986
    MacroAssembler _masm(cbuf);
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
   987
    int offset = __ offset();
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
   988
    switch (ireg) {
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
   989
    case Op_VecS:
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
   990
      __ pushl(Address(rsp, src_offset));
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
   991
      __ popl (Address(rsp, dst_offset));
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
   992
      break;
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
   993
    case Op_VecD:
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
   994
      __ pushl(Address(rsp, src_offset));
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
   995
      __ popl (Address(rsp, dst_offset));
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
   996
      __ pushl(Address(rsp, src_offset+4));
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
   997
      __ popl (Address(rsp, dst_offset+4));
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
   998
      break;
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
   999
    case Op_VecX:
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1000
      __ movdqu(Address(rsp, -16), xmm0);
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1001
      __ movdqu(xmm0, Address(rsp, src_offset));
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1002
      __ movdqu(Address(rsp, dst_offset), xmm0);
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1003
      __ movdqu(xmm0, Address(rsp, -16));
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1004
      break;
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1005
    case Op_VecY:
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1006
      __ vmovdqu(Address(rsp, -32), xmm0);
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1007
      __ vmovdqu(xmm0, Address(rsp, src_offset));
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1008
      __ vmovdqu(Address(rsp, dst_offset), xmm0);
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1009
      __ vmovdqu(xmm0, Address(rsp, -32));
30624
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
  1010
    case Op_VecZ:
32727
320855c2baef 8132160: support for AVX 512 call frames and stack management
mcberg
parents: 32082
diff changeset
  1011
      __ evmovdqul(Address(rsp, -64), xmm0, 2);
320855c2baef 8132160: support for AVX 512 call frames and stack management
mcberg
parents: 32082
diff changeset
  1012
      __ evmovdqul(xmm0, Address(rsp, src_offset), 2);
320855c2baef 8132160: support for AVX 512 call frames and stack management
mcberg
parents: 32082
diff changeset
  1013
      __ evmovdqul(Address(rsp, dst_offset), xmm0, 2);
320855c2baef 8132160: support for AVX 512 call frames and stack management
mcberg
parents: 32082
diff changeset
  1014
      __ evmovdqul(xmm0, Address(rsp, -64), 2);
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1015
      break;
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1016
    default:
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1017
      ShouldNotReachHere();
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1018
    }
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1019
    int size = __ offset() - offset;
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1020
    assert(size == calc_size, "incorrect size calculattion");
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1021
    return size;
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1022
#ifndef PRODUCT
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1023
  } else if (!do_size) {
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1024
    switch (ireg) {
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1025
    case Op_VecS:
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1026
      st->print("pushl   [rsp + #%d]\t# 32-bit mem-mem spill\n\t"
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1027
                "popl    [rsp + #%d]",
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1028
                src_offset, dst_offset);
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1029
      break;
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1030
    case Op_VecD:
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1031
      st->print("pushl   [rsp + #%d]\t# 64-bit mem-mem spill\n\t"
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1032
                "popq    [rsp + #%d]\n\t"
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1033
                "pushl   [rsp + #%d]\n\t"
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1034
                "popq    [rsp + #%d]",
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1035
                src_offset, dst_offset, src_offset+4, dst_offset+4);
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1036
      break;
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1037
     case Op_VecX:
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1038
      st->print("movdqu  [rsp - #16], xmm0\t# 128-bit mem-mem spill\n\t"
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1039
                "movdqu  xmm0, [rsp + #%d]\n\t"
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1040
                "movdqu  [rsp + #%d], xmm0\n\t"
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1041
                "movdqu  xmm0, [rsp - #16]",
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1042
                src_offset, dst_offset);
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1043
      break;
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1044
    case Op_VecY:
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1045
      st->print("vmovdqu [rsp - #32], xmm0\t# 256-bit mem-mem spill\n\t"
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1046
                "vmovdqu xmm0, [rsp + #%d]\n\t"
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1047
                "vmovdqu [rsp + #%d], xmm0\n\t"
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1048
                "vmovdqu xmm0, [rsp - #32]",
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1049
                src_offset, dst_offset);
30624
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
  1050
    case Op_VecZ:
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
  1051
      st->print("vmovdqu [rsp - #64], xmm0\t# 512-bit mem-mem spill\n\t"
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
  1052
                "vmovdqu xmm0, [rsp + #%d]\n\t"
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
  1053
                "vmovdqu [rsp + #%d], xmm0\n\t"
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
  1054
                "vmovdqu xmm0, [rsp - #64]",
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
  1055
                src_offset, dst_offset);
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1056
      break;
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1057
    default:
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1058
      ShouldNotReachHere();
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1059
    }
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1060
#endif
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1061
  }
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1062
  return calc_size;
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1063
}
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1064
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1065
uint MachSpillCopyNode::implementation( CodeBuffer *cbuf, PhaseRegAlloc *ra_, bool do_size, outputStream* st ) const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1066
  // Get registers to move
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1067
  OptoReg::Name src_second = ra_->get_reg_second(in(1));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1068
  OptoReg::Name src_first = ra_->get_reg_first(in(1));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1069
  OptoReg::Name dst_second = ra_->get_reg_second(this );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1070
  OptoReg::Name dst_first = ra_->get_reg_first(this );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1071
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1072
  enum RC src_second_rc = rc_class(src_second);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1073
  enum RC src_first_rc = rc_class(src_first);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1074
  enum RC dst_second_rc = rc_class(dst_second);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1075
  enum RC dst_first_rc = rc_class(dst_first);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1076
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1077
  assert( OptoReg::is_valid(src_first) && OptoReg::is_valid(dst_first), "must move at least 1 register" );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1078
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1079
  // Generate spill code!
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1080
  int size = 0;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1081
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1082
  if( src_first == dst_first && src_second == dst_second )
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1083
    return size;            // Self copy, no move
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1084
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1085
  if (bottom_type()->isa_vect() != NULL) {
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1086
    uint ireg = ideal_reg();
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1087
    assert((src_first_rc != rc_int && dst_first_rc != rc_int), "sanity");
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1088
    assert((src_first_rc != rc_float && dst_first_rc != rc_float), "sanity");
30624
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
  1089
    assert((ireg == Op_VecS || ireg == Op_VecD || ireg == Op_VecX || ireg == Op_VecY || ireg == Op_VecZ ), "sanity");
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1090
    if( src_first_rc == rc_stack && dst_first_rc == rc_stack ) {
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1091
      // mem -> mem
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1092
      int src_offset = ra_->reg2offset(src_first);
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1093
      int dst_offset = ra_->reg2offset(dst_first);
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1094
      return vec_stack_to_stack_helper(cbuf, do_size, src_offset, dst_offset, ireg, st);
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1095
    } else if (src_first_rc == rc_xmm && dst_first_rc == rc_xmm ) {
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1096
      return vec_mov_helper(cbuf, do_size, src_first, dst_first, src_second, dst_second, ireg, st);
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1097
    } else if (src_first_rc == rc_xmm && dst_first_rc == rc_stack ) {
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1098
      int stack_offset = ra_->reg2offset(dst_first);
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1099
      return vec_spill_helper(cbuf, do_size, false, stack_offset, src_first, ireg, st);
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1100
    } else if (src_first_rc == rc_stack && dst_first_rc == rc_xmm ) {
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1101
      int stack_offset = ra_->reg2offset(src_first);
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1102
      return vec_spill_helper(cbuf, do_size, true,  stack_offset, dst_first, ireg, st);
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1103
    } else {
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1104
      ShouldNotReachHere();
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1105
    }
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1106
  }
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1107
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1108
  // --------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1109
  // Check for mem-mem move.  push/pop to move.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1110
  if( src_first_rc == rc_stack && dst_first_rc == rc_stack ) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1111
    if( src_second == dst_first ) { // overlapping stack copy ranges
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1112
      assert( src_second_rc == rc_stack && dst_second_rc == rc_stack, "we only expect a stk-stk copy here" );
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  1113
      size = impl_helper(cbuf,do_size,true ,ra_->reg2offset(src_second),ESI_num,0xFF,"PUSH  ",size, st);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  1114
      size = impl_helper(cbuf,do_size,false,ra_->reg2offset(dst_second),EAX_num,0x8F,"POP   ",size, st);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1115
      src_second_rc = dst_second_rc = rc_bad;  // flag as already moved the second bits
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1116
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1117
    // move low bits
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  1118
    size = impl_helper(cbuf,do_size,true ,ra_->reg2offset(src_first),ESI_num,0xFF,"PUSH  ",size, st);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  1119
    size = impl_helper(cbuf,do_size,false,ra_->reg2offset(dst_first),EAX_num,0x8F,"POP   ",size, st);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1120
    if( src_second_rc == rc_stack && dst_second_rc == rc_stack ) { // mov second bits
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  1121
      size = impl_helper(cbuf,do_size,true ,ra_->reg2offset(src_second),ESI_num,0xFF,"PUSH  ",size, st);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  1122
      size = impl_helper(cbuf,do_size,false,ra_->reg2offset(dst_second),EAX_num,0x8F,"POP   ",size, st);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1123
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1124
    return size;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1125
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1126
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1127
  // --------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1128
  // Check for integer reg-reg copy
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1129
  if( src_first_rc == rc_int && dst_first_rc == rc_int )
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  1130
    size = impl_mov_helper(cbuf,do_size,src_first,dst_first,size, st);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1131
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1132
  // Check for integer store
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1133
  if( src_first_rc == rc_int && dst_first_rc == rc_stack )
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  1134
    size = impl_helper(cbuf,do_size,false,ra_->reg2offset(dst_first),src_first,0x89,"MOV ",size, st);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1135
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1136
  // Check for integer load
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1137
  if( dst_first_rc == rc_int && src_first_rc == rc_stack )
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  1138
    size = impl_helper(cbuf,do_size,true ,ra_->reg2offset(src_first),dst_first,0x8B,"MOV ",size, st);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1139
6272
94a20ad0e9de 6978249: spill between cpu and fpu registers when those moves are fast
never
parents: 5702
diff changeset
  1140
  // Check for integer reg-xmm reg copy
94a20ad0e9de 6978249: spill between cpu and fpu registers when those moves are fast
never
parents: 5702
diff changeset
  1141
  if( src_first_rc == rc_int && dst_first_rc == rc_xmm ) {
94a20ad0e9de 6978249: spill between cpu and fpu registers when those moves are fast
never
parents: 5702
diff changeset
  1142
    assert( (src_second_rc == rc_bad && dst_second_rc == rc_bad),
94a20ad0e9de 6978249: spill between cpu and fpu registers when those moves are fast
never
parents: 5702
diff changeset
  1143
            "no 64 bit integer-float reg moves" );
94a20ad0e9de 6978249: spill between cpu and fpu registers when those moves are fast
never
parents: 5702
diff changeset
  1144
    return impl_movgpr2x_helper(cbuf,do_size,src_first,dst_first,src_second, dst_second, size, st);
94a20ad0e9de 6978249: spill between cpu and fpu registers when those moves are fast
never
parents: 5702
diff changeset
  1145
  }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1146
  // --------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1147
  // Check for float reg-reg copy
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1148
  if( src_first_rc == rc_float && dst_first_rc == rc_float ) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1149
    assert( (src_second_rc == rc_bad && dst_second_rc == rc_bad) ||
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1150
            (src_first+1 == src_second && dst_first+1 == dst_second), "no non-adjacent float-moves" );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1151
    if( cbuf ) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1152
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1153
      // Note the mucking with the register encode to compensate for the 0/1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1154
      // indexing issue mentioned in a comment in the reg_def sections
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1155
      // for FPR registers many lines above here.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1156
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1157
      if( src_first != FPR1L_num ) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1158
        emit_opcode  (*cbuf, 0xD9 );           // FLD    ST(i)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1159
        emit_d8      (*cbuf, 0xC0+Matcher::_regEncode[src_first]-1 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1160
        emit_opcode  (*cbuf, 0xDD );           // FSTP   ST(i)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1161
        emit_d8      (*cbuf, 0xD8+Matcher::_regEncode[dst_first] );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1162
     } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1163
        emit_opcode  (*cbuf, 0xDD );           // FST    ST(i)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1164
        emit_d8      (*cbuf, 0xD0+Matcher::_regEncode[dst_first]-1 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1165
     }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1166
#ifndef PRODUCT
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1167
    } else if( !do_size ) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1168
      if( size != 0 ) st->print("\n\t");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1169
      if( src_first != FPR1L_num ) st->print("FLD    %s\n\tFSTP   %s",Matcher::regName[src_first],Matcher::regName[dst_first]);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1170
      else                      st->print(             "FST    %s",                            Matcher::regName[dst_first]);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1171
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1172
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1173
    return size + ((src_first != FPR1L_num) ? 2+2 : 2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1174
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1175
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1176
  // Check for float store
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1177
  if( src_first_rc == rc_float && dst_first_rc == rc_stack ) {
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  1178
    return impl_fp_store_helper(cbuf,do_size,src_first,src_second,dst_first,dst_second,ra_->reg2offset(dst_first),size, st);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1179
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1180
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1181
  // Check for float load
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1182
  if( dst_first_rc == rc_float && src_first_rc == rc_stack ) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1183
    int offset = ra_->reg2offset(src_first);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1184
    const char *op_str;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1185
    int op;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1186
    if( src_first+1 == src_second && dst_first+1 == dst_second ) { // double load?
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1187
      op_str = "FLD_D";
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1188
      op = 0xDD;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1189
    } else {                   // 32-bit load
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1190
      op_str = "FLD_S";
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1191
      op = 0xD9;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1192
      assert( src_second_rc == rc_bad && dst_second_rc == rc_bad, "no non-adjacent float-loads" );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1193
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1194
    if( cbuf ) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1195
      emit_opcode  (*cbuf, op );
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13485
diff changeset
  1196
      encode_RegMem(*cbuf, 0x0, ESP_enc, 0x4, 0, offset, relocInfo::none);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1197
      emit_opcode  (*cbuf, 0xDD );           // FSTP   ST(i)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1198
      emit_d8      (*cbuf, 0xD8+Matcher::_regEncode[dst_first] );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1199
#ifndef PRODUCT
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1200
    } else if( !do_size ) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1201
      if( size != 0 ) st->print("\n\t");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1202
      st->print("%s  ST,[ESP + #%d]\n\tFSTP   %s",op_str, offset,Matcher::regName[dst_first]);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1203
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1204
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1205
    int offset_size = (offset == 0) ? 0 : ((offset <= 127) ? 1 : 4);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1206
    return size + 3+offset_size+2;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1207
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1208
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1209
  // Check for xmm reg-reg copy
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1210
  if( src_first_rc == rc_xmm && dst_first_rc == rc_xmm ) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1211
    assert( (src_second_rc == rc_bad && dst_second_rc == rc_bad) ||
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1212
            (src_first+1 == src_second && dst_first+1 == dst_second),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1213
            "no non-adjacent float-moves" );
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  1214
    return impl_movx_helper(cbuf,do_size,src_first,dst_first,src_second, dst_second, size, st);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1215
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1216
6272
94a20ad0e9de 6978249: spill between cpu and fpu registers when those moves are fast
never
parents: 5702
diff changeset
  1217
  // Check for xmm reg-integer reg copy
94a20ad0e9de 6978249: spill between cpu and fpu registers when those moves are fast
never
parents: 5702
diff changeset
  1218
  if( src_first_rc == rc_xmm && dst_first_rc == rc_int ) {
94a20ad0e9de 6978249: spill between cpu and fpu registers when those moves are fast
never
parents: 5702
diff changeset
  1219
    assert( (src_second_rc == rc_bad && dst_second_rc == rc_bad),
94a20ad0e9de 6978249: spill between cpu and fpu registers when those moves are fast
never
parents: 5702
diff changeset
  1220
            "no 64 bit float-integer reg moves" );
94a20ad0e9de 6978249: spill between cpu and fpu registers when those moves are fast
never
parents: 5702
diff changeset
  1221
    return impl_movx2gpr_helper(cbuf,do_size,src_first,dst_first,src_second, dst_second, size, st);
94a20ad0e9de 6978249: spill between cpu and fpu registers when those moves are fast
never
parents: 5702
diff changeset
  1222
  }
94a20ad0e9de 6978249: spill between cpu and fpu registers when those moves are fast
never
parents: 5702
diff changeset
  1223
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1224
  // Check for xmm store
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1225
  if( src_first_rc == rc_xmm && dst_first_rc == rc_stack ) {
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  1226
    return impl_x_helper(cbuf,do_size,false,ra_->reg2offset(dst_first),src_first, src_second, size, st);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1227
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1228
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1229
  // Check for float xmm load
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1230
  if( dst_first_rc == rc_xmm && src_first_rc == rc_stack ) {
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  1231
    return impl_x_helper(cbuf,do_size,true ,ra_->reg2offset(src_first),dst_first, dst_second, size, st);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1232
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1233
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1234
  // Copy from float reg to xmm reg
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1235
  if( dst_first_rc == rc_xmm && src_first_rc == rc_float ) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1236
    // copy to the top of stack from floating point reg
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1237
    // and use LEA to preserve flags
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1238
    if( cbuf ) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1239
      emit_opcode(*cbuf,0x8D);  // LEA  ESP,[ESP-8]
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1240
      emit_rm(*cbuf, 0x1, ESP_enc, 0x04);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1241
      emit_rm(*cbuf, 0x0, 0x04, ESP_enc);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1242
      emit_d8(*cbuf,0xF8);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1243
#ifndef PRODUCT
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1244
    } else if( !do_size ) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1245
      if( size != 0 ) st->print("\n\t");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1246
      st->print("LEA    ESP,[ESP-8]");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1247
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1248
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1249
    size += 4;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1250
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  1251
    size = impl_fp_store_helper(cbuf,do_size,src_first,src_second,dst_first,dst_second,0,size, st);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1252
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1253
    // Copy from the temp memory to the xmm reg.
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  1254
    size = impl_x_helper(cbuf,do_size,true ,0,dst_first, dst_second, size, st);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1255
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1256
    if( cbuf ) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1257
      emit_opcode(*cbuf,0x8D);  // LEA  ESP,[ESP+8]
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1258
      emit_rm(*cbuf, 0x1, ESP_enc, 0x04);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1259
      emit_rm(*cbuf, 0x0, 0x04, ESP_enc);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1260
      emit_d8(*cbuf,0x08);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1261
#ifndef PRODUCT
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1262
    } else if( !do_size ) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1263
      if( size != 0 ) st->print("\n\t");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1264
      st->print("LEA    ESP,[ESP+8]");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1265
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1266
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1267
    size += 4;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1268
    return size;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1269
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1270
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1271
  assert( size > 0, "missed a case" );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1272
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1273
  // --------------------------------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1274
  // Check for second bits still needing moving.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1275
  if( src_second == dst_second )
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1276
    return size;               // Self copy; no move
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1277
  assert( src_second_rc != rc_bad && dst_second_rc != rc_bad, "src_second & dst_second cannot be Bad" );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1278
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1279
  // Check for second word int-int move
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1280
  if( src_second_rc == rc_int && dst_second_rc == rc_int )
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  1281
    return impl_mov_helper(cbuf,do_size,src_second,dst_second,size, st);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1282
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1283
  // Check for second word integer store
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1284
  if( src_second_rc == rc_int && dst_second_rc == rc_stack )
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  1285
    return impl_helper(cbuf,do_size,false,ra_->reg2offset(dst_second),src_second,0x89,"MOV ",size, st);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1286
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1287
  // Check for second word integer load
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1288
  if( dst_second_rc == rc_int && src_second_rc == rc_stack )
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  1289
    return impl_helper(cbuf,do_size,true ,ra_->reg2offset(src_second),dst_second,0x8B,"MOV ",size, st);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1290
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1291
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1292
  Unimplemented();
27677
b1997f2f1b56 8062808: Turn on the -Wreturn-type warning
stefank
parents: 24923
diff changeset
  1293
  return 0; // Mute compiler
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1294
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1295
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1296
#ifndef PRODUCT
11794
72249bf6ab83 7145346: VerifyStackAtCalls is broken
kvn
parents: 11791
diff changeset
  1297
void MachSpillCopyNode::format(PhaseRegAlloc *ra_, outputStream* st) const {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1298
  implementation( NULL, ra_, false, st );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1299
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1300
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1301
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1302
void MachSpillCopyNode::emit(CodeBuffer &cbuf, PhaseRegAlloc *ra_) const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1303
  implementation( &cbuf, ra_, false, NULL );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1304
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1305
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1306
uint MachSpillCopyNode::size(PhaseRegAlloc *ra_) const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1307
  return implementation( NULL, ra_, true, NULL );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1308
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1309
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1310
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1311
//=============================================================================
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1312
#ifndef PRODUCT
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1313
void BoxLockNode::format( PhaseRegAlloc *ra_, outputStream* st ) const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1314
  int offset = ra_->reg2offset(in_RegMask(0).find_first_elem());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1315
  int reg = ra_->get_reg_first(this);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1316
  st->print("LEA    %s,[ESP + #%d]",Matcher::regName[reg],offset);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1317
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1318
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1319
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1320
void BoxLockNode::emit(CodeBuffer &cbuf, PhaseRegAlloc *ra_) const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1321
  int offset = ra_->reg2offset(in_RegMask(0).find_first_elem());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1322
  int reg = ra_->get_encode(this);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1323
  if( offset >= 128 ) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1324
    emit_opcode(cbuf, 0x8D);      // LEA  reg,[SP+offset]
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1325
    emit_rm(cbuf, 0x2, reg, 0x04);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1326
    emit_rm(cbuf, 0x0, 0x04, ESP_enc);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1327
    emit_d32(cbuf, offset);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1328
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1329
  else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1330
    emit_opcode(cbuf, 0x8D);      // LEA  reg,[SP+offset]
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1331
    emit_rm(cbuf, 0x1, reg, 0x04);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1332
    emit_rm(cbuf, 0x0, 0x04, ESP_enc);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1333
    emit_d8(cbuf, offset);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1334
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1335
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1336
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1337
uint BoxLockNode::size(PhaseRegAlloc *ra_) const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1338
  int offset = ra_->reg2offset(in_RegMask(0).find_first_elem());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1339
  if( offset >= 128 ) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1340
    return 7;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1341
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1342
  else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1343
    return 4;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1344
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1345
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1346
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1347
//=============================================================================
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1348
#ifndef PRODUCT
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1349
void MachUEPNode::format( PhaseRegAlloc *ra_, outputStream* st ) const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1350
  st->print_cr(  "CMP    EAX,[ECX+4]\t# Inline cache check");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1351
  st->print_cr("\tJNE    SharedRuntime::handle_ic_miss_stub");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1352
  st->print_cr("\tNOP");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1353
  st->print_cr("\tNOP");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1354
  if( !OptoBreakpoint )
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1355
    st->print_cr("\tNOP");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1356
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1357
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1358
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1359
void MachUEPNode::emit(CodeBuffer &cbuf, PhaseRegAlloc *ra_) const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1360
  MacroAssembler masm(&cbuf);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1361
#ifdef ASSERT
6418
6671edbd230e 6978355: renaming for 6961697
twisti
parents: 6272
diff changeset
  1362
  uint insts_size = cbuf.insts_size();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1363
#endif
1066
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  1364
  masm.cmpptr(rax, Address(rcx, oopDesc::klass_offset_in_bytes()));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1365
  masm.jump_cc(Assembler::notEqual,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1366
               RuntimeAddress(SharedRuntime::get_ic_miss_stub()));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1367
  /* WARNING these NOPs are critical so that verified entry point is properly
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1368
     aligned for patching by NativeJump::patch_verified_entry() */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1369
  int nops_cnt = 2;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1370
  if( !OptoBreakpoint ) // Leave space for int3
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1371
     nops_cnt += 1;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1372
  masm.nop(nops_cnt);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1373
6418
6671edbd230e 6978355: renaming for 6961697
twisti
parents: 6272
diff changeset
  1374
  assert(cbuf.insts_size() - insts_size == size(ra_), "checking code size of inline cache node");
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1375
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1376
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1377
uint MachUEPNode::size(PhaseRegAlloc *ra_) const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1378
  return OptoBreakpoint ? 11 : 12;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1379
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1380
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1381
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1382
//=============================================================================
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1383
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1384
int Matcher::regnum_to_fpu_offset(int regnum) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1385
  return regnum - 32; // The FP registers are in the second chunk
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1386
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1387
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1388
// This is UltraSparc specific, true just means we have fast l2f conversion
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1389
const bool Matcher::convL2FSupported(void) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1390
  return true;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1391
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1392
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1393
// Is this branch offset short enough that a short branch can be used?
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1394
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1395
// NOTE: If the platform does not provide any short branch variants, then
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1396
//       this method should return false for offset 0.
10264
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
  1397
bool Matcher::is_short_branch_offset(int rule, int br_size, int offset) {
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
  1398
  // The passed offset is relative to address of the branch.
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
  1399
  // On 86 a branch displacement is calculated relative to address
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
  1400
  // of a next instruction.
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
  1401
  offset -= br_size;
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
  1402
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  1403
  // the short version of jmpConUCF2 contains multiple branches,
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  1404
  // making the reach slightly less
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  1405
  if (rule == jmpConUCF2_rule)
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  1406
    return (-126 <= offset && offset <= 125);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1407
  return (-128 <= offset && offset <= 127);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1408
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1409
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1410
const bool Matcher::isSimpleConstant64(jlong value) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1411
  // Will one (StoreL ConL) be cheaper than two (StoreI ConI)?.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1412
  return false;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1413
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1414
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1415
// The ecx parameter to rep stos for the ClearArray node is in dwords.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1416
const bool Matcher::init_array_count_is_in_bytes = false;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1417
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1418
// Threshold size for cleararray.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1419
const int Matcher::init_array_short_size = 8 * BytesPerLong;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1420
10971
db45f6ab9a75 7097546: Optimize use of CMOVE instructions
kvn
parents: 10267
diff changeset
  1421
// Needs 2 CMOV's for longs.
db45f6ab9a75 7097546: Optimize use of CMOVE instructions
kvn
parents: 10267
diff changeset
  1422
const int Matcher::long_cmove_cost() { return 1; }
db45f6ab9a75 7097546: Optimize use of CMOVE instructions
kvn
parents: 10267
diff changeset
  1423
db45f6ab9a75 7097546: Optimize use of CMOVE instructions
kvn
parents: 10267
diff changeset
  1424
// No CMOVF/CMOVD with SSE/SSE2
db45f6ab9a75 7097546: Optimize use of CMOVE instructions
kvn
parents: 10267
diff changeset
  1425
const int Matcher::float_cmove_cost() { return (UseSSE>=1) ? ConditionalMoveLimit : 0; }
db45f6ab9a75 7097546: Optimize use of CMOVE instructions
kvn
parents: 10267
diff changeset
  1426
22844
90f76a40ed8a 8003854: PPC64 (part 115): Introduce PostallocExpand that expands nodes after register allocation
goetz
parents: 22838
diff changeset
  1427
// Does the CPU require late expand (see block.cpp for description of late expand)?
90f76a40ed8a 8003854: PPC64 (part 115): Introduce PostallocExpand that expands nodes after register allocation
goetz
parents: 22838
diff changeset
  1428
const bool Matcher::require_postalloc_expand = false;
90f76a40ed8a 8003854: PPC64 (part 115): Introduce PostallocExpand that expands nodes after register allocation
goetz
parents: 22838
diff changeset
  1429
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1430
// Should the Matcher clone shifts on addressing modes, expecting them to
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1431
// be subsumed into complex addressing expressions or compute them into
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1432
// registers?  True for Intel but false for most RISCs
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1433
const bool Matcher::clone_shift_expressions = true;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1434
8868
1bae515b806b 7029017: Additional architecture support for c2 compiler
roland
parents: 8494
diff changeset
  1435
// Do we need to mask the count passed to shift instructions or does
1bae515b806b 7029017: Additional architecture support for c2 compiler
roland
parents: 8494
diff changeset
  1436
// the cpu only look at the lower 5/6 bits anyway?
1bae515b806b 7029017: Additional architecture support for c2 compiler
roland
parents: 8494
diff changeset
  1437
const bool Matcher::need_masked_shift_count = false;
1bae515b806b 7029017: Additional architecture support for c2 compiler
roland
parents: 8494
diff changeset
  1438
5698
091095915ee6 6954029: Improve implicit null check generation with compressed oops
kvn
parents: 5690
diff changeset
  1439
bool Matcher::narrow_oop_use_complex_address() {
091095915ee6 6954029: Improve implicit null check generation with compressed oops
kvn
parents: 5690
diff changeset
  1440
  ShouldNotCallThis();
091095915ee6 6954029: Improve implicit null check generation with compressed oops
kvn
parents: 5690
diff changeset
  1441
  return true;
091095915ee6 6954029: Improve implicit null check generation with compressed oops
kvn
parents: 5690
diff changeset
  1442
}
091095915ee6 6954029: Improve implicit null check generation with compressed oops
kvn
parents: 5690
diff changeset
  1443
13969
d2a189b83b87 7054512: Compress class pointers after perm gen removal
roland
parents: 13886
diff changeset
  1444
bool Matcher::narrow_klass_use_complex_address() {
d2a189b83b87 7054512: Compress class pointers after perm gen removal
roland
parents: 13886
diff changeset
  1445
  ShouldNotCallThis();
d2a189b83b87 7054512: Compress class pointers after perm gen removal
roland
parents: 13886
diff changeset
  1446
  return true;
d2a189b83b87 7054512: Compress class pointers after perm gen removal
roland
parents: 13886
diff changeset
  1447
}
d2a189b83b87 7054512: Compress class pointers after perm gen removal
roland
parents: 13886
diff changeset
  1448
5698
091095915ee6 6954029: Improve implicit null check generation with compressed oops
kvn
parents: 5690
diff changeset
  1449
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1450
// Is it better to copy float constants, or load them directly from memory?
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1451
// Intel can load a float constant from a direct address, requiring no
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1452
// extra registers.  Most RISCs will have to materialize an address into a
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1453
// register first, so they would do better to copy the constant from stack.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1454
const bool Matcher::rematerialize_float_constants = true;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1455
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1456
// If CPU can load and store mis-aligned doubles directly then no fixup is
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1457
// needed.  Else we split the double into 2 integer pieces and move it
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1458
// piece-by-piece.  Only happens when passing doubles into C code as the
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1459
// Java calling convention forces doubles to be aligned.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1460
const bool Matcher::misaligned_doubles_ok = true;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1461
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1462
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1463
void Matcher::pd_implicit_null_fixup(MachNode *node, uint idx) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1464
  // Get the memory operand from the node
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1465
  uint numopnds = node->num_opnds();        // Virtual call for number of operands
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1466
  uint skipped  = node->oper_input_base();  // Sum of leaves skipped so far
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1467
  assert( idx >= skipped, "idx too low in pd_implicit_null_fixup" );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1468
  uint opcnt     = 1;                 // First operand
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1469
  uint num_edges = node->_opnds[1]->num_edges(); // leaves for first operand
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1470
  while( idx >= skipped+num_edges ) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1471
    skipped += num_edges;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1472
    opcnt++;                          // Bump operand count
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1473
    assert( opcnt < numopnds, "Accessing non-existent operand" );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1474
    num_edges = node->_opnds[opcnt]->num_edges(); // leaves for next operand
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1475
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1476
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1477
  MachOper *memory = node->_opnds[opcnt];
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1478
  MachOper *new_memory = NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1479
  switch (memory->opcode()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1480
  case DIRECT:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1481
  case INDOFFSET32X:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1482
    // No transformation necessary.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1483
    return;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1484
  case INDIRECT:
24923
9631f7d691dc 8034812: remove IDX_INIT macro hack in Node class
thartmann
parents: 24018
diff changeset
  1485
    new_memory = new indirect_win95_safeOper( );
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1486
    break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1487
  case INDOFFSET8:
24923
9631f7d691dc 8034812: remove IDX_INIT macro hack in Node class
thartmann
parents: 24018
diff changeset
  1488
    new_memory = new indOffset8_win95_safeOper(memory->disp(NULL, NULL, 0));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1489
    break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1490
  case INDOFFSET32:
24923
9631f7d691dc 8034812: remove IDX_INIT macro hack in Node class
thartmann
parents: 24018
diff changeset
  1491
    new_memory = new indOffset32_win95_safeOper(memory->disp(NULL, NULL, 0));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1492
    break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1493
  case INDINDEXOFFSET:
24923
9631f7d691dc 8034812: remove IDX_INIT macro hack in Node class
thartmann
parents: 24018
diff changeset
  1494
    new_memory = new indIndexOffset_win95_safeOper(memory->disp(NULL, NULL, 0));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1495
    break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1496
  case INDINDEXSCALE:
24923
9631f7d691dc 8034812: remove IDX_INIT macro hack in Node class
thartmann
parents: 24018
diff changeset
  1497
    new_memory = new indIndexScale_win95_safeOper(memory->scale());
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1498
    break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1499
  case INDINDEXSCALEOFFSET:
24923
9631f7d691dc 8034812: remove IDX_INIT macro hack in Node class
thartmann
parents: 24018
diff changeset
  1500
    new_memory = new indIndexScaleOffset_win95_safeOper(memory->scale(), memory->disp(NULL, NULL, 0));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1501
    break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1502
  case LOAD_LONG_INDIRECT:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1503
  case LOAD_LONG_INDOFFSET32:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1504
    // Does not use EBP as address register, use { EDX, EBX, EDI, ESI}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1505
    return;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1506
  default:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1507
    assert(false, "unexpected memory operand in pd_implicit_null_fixup()");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1508
    return;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1509
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1510
  node->_opnds[opcnt] = new_memory;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1511
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1512
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1513
// Advertise here if the CPU requires explicit rounding operations
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1514
// to implement the UseStrictFP mode.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1515
const bool Matcher::strict_fp_requires_explicit_rounding = true;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1516
5025
05adc9b8f96a 6910664: C2: java/util/Arrays/Sorting.java fails with DeoptimizeALot flag
kvn
parents: 4757
diff changeset
  1517
// Are floats conerted to double when stored to stack during deoptimization?
05adc9b8f96a 6910664: C2: java/util/Arrays/Sorting.java fails with DeoptimizeALot flag
kvn
parents: 4757
diff changeset
  1518
// On x32 it is stored with convertion only when FPU is used for floats.
05adc9b8f96a 6910664: C2: java/util/Arrays/Sorting.java fails with DeoptimizeALot flag
kvn
parents: 4757
diff changeset
  1519
bool Matcher::float_in_double() { return (UseSSE == 0); }
05adc9b8f96a 6910664: C2: java/util/Arrays/Sorting.java fails with DeoptimizeALot flag
kvn
parents: 4757
diff changeset
  1520
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1521
// Do ints take an entire long register or just half?
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1522
const bool Matcher::int_in_long = false;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1523
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1524
// Return whether or not this register is ever used as an argument.  This
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1525
// function is used on startup to build the trampoline stubs in generateOptoStub.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1526
// Registers not mentioned will be killed by the VM call in the trampoline, and
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1527
// arguments in those registers not be available to the callee.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1528
bool Matcher::can_be_java_arg( int reg ) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1529
  if(  reg == ECX_num   || reg == EDX_num   ) return true;
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1530
  if( (reg == XMM0_num  || reg == XMM1_num ) && UseSSE>=1 ) return true;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1531
  if( (reg == XMM0b_num || reg == XMM1b_num) && UseSSE>=2 ) return true;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1532
  return false;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1533
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1534
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1535
bool Matcher::is_spillable_arg( int reg ) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1536
  return can_be_java_arg(reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1537
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1538
7115
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  1539
bool Matcher::use_asm_for_ldiv_by_con( jlong divisor ) {
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  1540
  // Use hardware integer DIV instruction when
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  1541
  // it is faster than a code which use multiply.
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  1542
  // Only when constant divisor fits into 32 bit
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  1543
  // (min_jint is excluded to get only correct
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  1544
  // positive 32 bit values from negative).
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  1545
  return VM_Version::has_fast_idiv() &&
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  1546
         (divisor == (int)divisor && divisor != min_jint);
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  1547
}
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  1548
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1549
// Register for DIVI projection of divmodI
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1550
RegMask Matcher::divI_proj_mask() {
11197
158eecd6b330 7090968: Allow adlc register class to depend on runtime conditions
roland
parents: 11190
diff changeset
  1551
  return EAX_REG_mask();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1552
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1553
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1554
// Register for MODI projection of divmodI
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1555
RegMask Matcher::modI_proj_mask() {
11197
158eecd6b330 7090968: Allow adlc register class to depend on runtime conditions
roland
parents: 11190
diff changeset
  1556
  return EDX_REG_mask();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1557
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1558
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1559
// Register for DIVL projection of divmodL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1560
RegMask Matcher::divL_proj_mask() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1561
  ShouldNotReachHere();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1562
  return RegMask();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1563
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1564
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1565
// Register for MODL projection of divmodL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1566
RegMask Matcher::modL_proj_mask() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1567
  ShouldNotReachHere();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1568
  return RegMask();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1569
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1570
4566
b363f6ef4068 6829187: compiler optimizations required for JSR 292
twisti
parents: 3908
diff changeset
  1571
const RegMask Matcher::method_handle_invoke_SP_save_mask() {
30305
b92a97e1e9cb 8068945: Use RBP register as proper frame pointer in JIT compiled code on x86
zmajo
parents: 28954
diff changeset
  1572
  return NO_REG_mask();
4566
b363f6ef4068 6829187: compiler optimizations required for JSR 292
twisti
parents: 3908
diff changeset
  1573
}
b363f6ef4068 6829187: compiler optimizations required for JSR 292
twisti
parents: 3908
diff changeset
  1574
4757
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
  1575
// Returns true if the high 32 bits of the value is known to be zero.
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
  1576
bool is_operand_hi32_zero(Node* n) {
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
  1577
  int opc = n->Opcode();
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
  1578
  if (opc == Op_AndL) {
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
  1579
    Node* o2 = n->in(2);
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
  1580
    if (o2->is_Con() && (o2->get_long() & 0xFFFFFFFF00000000LL) == 0LL) {
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
  1581
      return true;
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
  1582
    }
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
  1583
  }
7115
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  1584
  if (opc == Op_ConL && (n->get_long() & 0xFFFFFFFF00000000LL) == 0LL) {
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  1585
    return true;
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  1586
  }
4757
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
  1587
  return false;
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
  1588
}
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
  1589
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1590
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1591
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1592
//----------ENCODING BLOCK-----------------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1593
// This block specifies the encoding classes used by the compiler to output
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1594
// byte streams.  Encoding classes generate functions which are called by
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1595
// Machine Instruction Nodes in order to generate the bit encoding of the
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1596
// instruction.  Operands specify their base encoding interface with the
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1597
// interface keyword.  There are currently supported four interfaces,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1598
// REG_INTER, CONST_INTER, MEMORY_INTER, & COND_INTER.  REG_INTER causes an
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1599
// operand to generate a function which returns its register number when
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1600
// queried.   CONST_INTER causes an operand to generate a function which
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1601
// returns the value of the constant when queried.  MEMORY_INTER causes an
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1602
// operand to generate four functions which return the Base Register, the
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1603
// Index Register, the Scale Value, and the Offset Value of the operand when
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1604
// queried.  COND_INTER causes an operand to generate six functions which
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1605
// return the encoding code (ie - encoding bits for the instruction)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1606
// associated with each basic boolean condition for a conditional instruction.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1607
// Instructions specify two basic values for encoding.  They use the
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1608
// ins_encode keyword to specify their encoding class (which must be one of
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1609
// the class names specified in the encoding block), and they use the
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1610
// opcode keyword to specify, in order, their primary, secondary, and
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1611
// tertiary opcode.  Only the opcode sections which a particular instruction
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1612
// needs for encoding need to be specified.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1613
encode %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1614
  // Build emit functions for each basic byte or larger field in the intel
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1615
  // encoding scheme (opcode, rm, sib, immediate), and call them from C++
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1616
  // code in the enc_class source block.  Emit functions will live in the
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1617
  // main source block for now.  In future, we can generalize this by
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1618
  // adding a syntax that specifies the sizes of fields in an order,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1619
  // so that the adlc can build the emit functions automagically
2255
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2150
diff changeset
  1620
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2150
diff changeset
  1621
  // Emit primary opcode
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2150
diff changeset
  1622
  enc_class OpcP %{
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2150
diff changeset
  1623
    emit_opcode(cbuf, $primary);
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2150
diff changeset
  1624
  %}
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2150
diff changeset
  1625
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2150
diff changeset
  1626
  // Emit secondary opcode
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2150
diff changeset
  1627
  enc_class OpcS %{
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2150
diff changeset
  1628
    emit_opcode(cbuf, $secondary);
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2150
diff changeset
  1629
  %}
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2150
diff changeset
  1630
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2150
diff changeset
  1631
  // Emit opcode directly
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2150
diff changeset
  1632
  enc_class Opcode(immI d8) %{
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2150
diff changeset
  1633
    emit_opcode(cbuf, $d8$$constant);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1634
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1635
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1636
  enc_class SizePrefix %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1637
    emit_opcode(cbuf,0x66);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1638
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1639
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1640
  enc_class RegReg (rRegI dst, rRegI src) %{    // RegReg(Many)
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1641
    emit_rm(cbuf, 0x3, $dst$$reg, $src$$reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1642
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1643
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1644
  enc_class OpcRegReg (immI opcode, rRegI dst, rRegI src) %{    // OpcRegReg(Many)
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1645
    emit_opcode(cbuf,$opcode$$constant);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1646
    emit_rm(cbuf, 0x3, $dst$$reg, $src$$reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1647
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1648
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1649
  enc_class mov_r32_imm0( rRegI dst ) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1650
    emit_opcode( cbuf, 0xB8 + $dst$$reg ); // 0xB8+ rd   -- MOV r32  ,imm32
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1651
    emit_d32   ( cbuf, 0x0  );             //                         imm32==0x0
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1652
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1653
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1654
  enc_class cdq_enc %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1655
    // Full implementation of Java idiv and irem; checks for
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1656
    // special case as described in JVM spec., p.243 & p.271.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1657
    //
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1658
    //         normal case                           special case
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1659
    //
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1660
    // input : rax,: dividend                         min_int
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1661
    //         reg: divisor                          -1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1662
    //
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1663
    // output: rax,: quotient  (= rax, idiv reg)       min_int
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1664
    //         rdx: remainder (= rax, irem reg)       0
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1665
    //
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1666
    //  Code sequnce:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1667
    //
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1668
    //  81 F8 00 00 00 80    cmp         rax,80000000h
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1669
    //  0F 85 0B 00 00 00    jne         normal_case
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1670
    //  33 D2                xor         rdx,edx
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1671
    //  83 F9 FF             cmp         rcx,0FFh
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1672
    //  0F 84 03 00 00 00    je          done
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1673
    //                  normal_case:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1674
    //  99                   cdq
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1675
    //  F7 F9                idiv        rax,ecx
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1676
    //                  done:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1677
    //
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1678
    emit_opcode(cbuf,0x81); emit_d8(cbuf,0xF8);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1679
    emit_opcode(cbuf,0x00); emit_d8(cbuf,0x00);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1680
    emit_opcode(cbuf,0x00); emit_d8(cbuf,0x80);                     // cmp rax,80000000h
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1681
    emit_opcode(cbuf,0x0F); emit_d8(cbuf,0x85);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1682
    emit_opcode(cbuf,0x0B); emit_d8(cbuf,0x00);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1683
    emit_opcode(cbuf,0x00); emit_d8(cbuf,0x00);                     // jne normal_case
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1684
    emit_opcode(cbuf,0x33); emit_d8(cbuf,0xD2);                     // xor rdx,edx
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1685
    emit_opcode(cbuf,0x83); emit_d8(cbuf,0xF9); emit_d8(cbuf,0xFF); // cmp rcx,0FFh
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1686
    emit_opcode(cbuf,0x0F); emit_d8(cbuf,0x84);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1687
    emit_opcode(cbuf,0x03); emit_d8(cbuf,0x00);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1688
    emit_opcode(cbuf,0x00); emit_d8(cbuf,0x00);                     // je done
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1689
    // normal_case:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1690
    emit_opcode(cbuf,0x99);                                         // cdq
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1691
    // idiv (note: must be emitted by the user of this rule)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1692
    // normal:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1693
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1694
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1695
  // Dense encoding for older common ops
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1696
  enc_class Opc_plus(immI opcode, rRegI reg) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1697
    emit_opcode(cbuf, $opcode$$constant + $reg$$reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1698
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1699
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1700
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1701
  // Opcde enc_class for 8/32 bit immediate instructions with sign-extension
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1702
  enc_class OpcSE (immI imm) %{ // Emit primary opcode and set sign-extend bit
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1703
    // Check for 8-bit immediate, and set sign extend bit in opcode
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1704
    if (($imm$$constant >= -128) && ($imm$$constant <= 127)) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1705
      emit_opcode(cbuf, $primary | 0x02);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1706
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1707
    else {                          // If 32-bit immediate
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1708
      emit_opcode(cbuf, $primary);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1709
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1710
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1711
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1712
  enc_class OpcSErm (rRegI dst, immI imm) %{    // OpcSEr/m
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1713
    // Emit primary opcode and set sign-extend bit
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1714
    // Check for 8-bit immediate, and set sign extend bit in opcode
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1715
    if (($imm$$constant >= -128) && ($imm$$constant <= 127)) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1716
      emit_opcode(cbuf, $primary | 0x02);    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1717
    else {                          // If 32-bit immediate
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1718
      emit_opcode(cbuf, $primary);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1719
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1720
    // Emit r/m byte with secondary opcode, after primary opcode.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1721
    emit_rm(cbuf, 0x3, $secondary, $dst$$reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1722
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1723
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1724
  enc_class Con8or32 (immI imm) %{    // Con8or32(storeImmI), 8 or 32 bits
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1725
    // Check for 8-bit immediate, and set sign extend bit in opcode
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1726
    if (($imm$$constant >= -128) && ($imm$$constant <= 127)) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1727
      $$$emit8$imm$$constant;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1728
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1729
    else {                          // If 32-bit immediate
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1730
      // Output immediate
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1731
      $$$emit32$imm$$constant;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1732
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1733
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1734
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1735
  enc_class Long_OpcSErm_Lo(eRegL dst, immL imm) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1736
    // Emit primary opcode and set sign-extend bit
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1737
    // Check for 8-bit immediate, and set sign extend bit in opcode
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1738
    int con = (int)$imm$$constant; // Throw away top bits
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1739
    emit_opcode(cbuf, ((con >= -128) && (con <= 127)) ? ($primary | 0x02) : $primary);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1740
    // Emit r/m byte with secondary opcode, after primary opcode.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1741
    emit_rm(cbuf, 0x3, $secondary, $dst$$reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1742
    if ((con >= -128) && (con <= 127)) emit_d8 (cbuf,con);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1743
    else                               emit_d32(cbuf,con);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1744
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1745
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1746
  enc_class Long_OpcSErm_Hi(eRegL dst, immL imm) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1747
    // Emit primary opcode and set sign-extend bit
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1748
    // Check for 8-bit immediate, and set sign extend bit in opcode
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1749
    int con = (int)($imm$$constant >> 32); // Throw away bottom bits
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1750
    emit_opcode(cbuf, ((con >= -128) && (con <= 127)) ? ($primary | 0x02) : $primary);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1751
    // Emit r/m byte with tertiary opcode, after primary opcode.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1752
    emit_rm(cbuf, 0x3, $tertiary, HIGH_FROM_LOW($dst$$reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1753
    if ((con >= -128) && (con <= 127)) emit_d8 (cbuf,con);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1754
    else                               emit_d32(cbuf,con);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1755
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1756
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1757
  enc_class OpcSReg (rRegI dst) %{    // BSWAP
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1758
    emit_cc(cbuf, $secondary, $dst$$reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1759
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1760
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1761
  enc_class bswap_long_bytes(eRegL dst) %{ // BSWAP
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1762
    int destlo = $dst$$reg;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1763
    int desthi = HIGH_FROM_LOW(destlo);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1764
    // bswap lo
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1765
    emit_opcode(cbuf, 0x0F);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1766
    emit_cc(cbuf, 0xC8, destlo);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1767
    // bswap hi
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1768
    emit_opcode(cbuf, 0x0F);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1769
    emit_cc(cbuf, 0xC8, desthi);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1770
    // xchg lo and hi
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1771
    emit_opcode(cbuf, 0x87);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1772
    emit_rm(cbuf, 0x3, destlo, desthi);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1773
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1774
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1775
  enc_class RegOpc (rRegI div) %{    // IDIV, IMOD, JMP indirect, ...
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1776
    emit_rm(cbuf, 0x3, $secondary, $div$$reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1777
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1778
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1779
  enc_class enc_cmov(cmpOp cop ) %{ // CMOV
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1780
    $$$emit8$primary;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1781
    emit_cc(cbuf, $secondary, $cop$$cmpcode);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1782
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1783
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  1784
  enc_class enc_cmov_dpr(cmpOp cop, regDPR src ) %{ // CMOV
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1785
    int op = 0xDA00 + $cop$$cmpcode + ($src$$reg-1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1786
    emit_d8(cbuf, op >> 8 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1787
    emit_d8(cbuf, op & 255);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1788
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1789
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1790
  // emulate a CMOV with a conditional branch around a MOV
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1791
  enc_class enc_cmov_branch( cmpOp cop, immI brOffs ) %{ // CMOV
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1792
    // Invert sense of branch from sense of CMOV
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1793
    emit_cc( cbuf, 0x70, ($cop$$cmpcode^1) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1794
    emit_d8( cbuf, $brOffs$$constant );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1795
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1796
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1797
  enc_class enc_PartialSubtypeCheck( ) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1798
    Register Redi = as_Register(EDI_enc); // result register
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1799
    Register Reax = as_Register(EAX_enc); // super class
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1800
    Register Recx = as_Register(ECX_enc); // killed
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1801
    Register Resi = as_Register(ESI_enc); // sub class
2256
82d4e10b7c6b 6813212: factor duplicated assembly code for general subclass check (for 6655638)
jrose
parents: 2255
diff changeset
  1802
    Label miss;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1803
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1804
    MacroAssembler _masm(&cbuf);
2256
82d4e10b7c6b 6813212: factor duplicated assembly code for general subclass check (for 6655638)
jrose
parents: 2255
diff changeset
  1805
    __ check_klass_subtype_slow_path(Resi, Reax, Recx, Redi,
82d4e10b7c6b 6813212: factor duplicated assembly code for general subclass check (for 6655638)
jrose
parents: 2255
diff changeset
  1806
                                     NULL, &miss,
82d4e10b7c6b 6813212: factor duplicated assembly code for general subclass check (for 6655638)
jrose
parents: 2255
diff changeset
  1807
                                     /*set_cond_codes:*/ true);
82d4e10b7c6b 6813212: factor duplicated assembly code for general subclass check (for 6655638)
jrose
parents: 2255
diff changeset
  1808
    if ($primary) {
82d4e10b7c6b 6813212: factor duplicated assembly code for general subclass check (for 6655638)
jrose
parents: 2255
diff changeset
  1809
      __ xorptr(Redi, Redi);
82d4e10b7c6b 6813212: factor duplicated assembly code for general subclass check (for 6655638)
jrose
parents: 2255
diff changeset
  1810
    }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1811
    __ bind(miss);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1812
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1813
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1814
  enc_class FFree_Float_Stack_All %{    // Free_Float_Stack_All
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1815
    MacroAssembler masm(&cbuf);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1816
    int start = masm.offset();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1817
    if (UseSSE >= 2) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1818
      if (VerifyFPU) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1819
        masm.verify_FPU(0, "must be empty in SSE2+ mode");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1820
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1821
    } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1822
      // External c_calling_convention expects the FPU stack to be 'clean'.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1823
      // Compiled code leaves it dirty.  Do cleanup now.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1824
      masm.empty_FPU_stack();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1825
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1826
    if (sizeof_FFree_Float_Stack_All == -1) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1827
      sizeof_FFree_Float_Stack_All = masm.offset() - start;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1828
    } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1829
      assert(masm.offset() - start == sizeof_FFree_Float_Stack_All, "wrong size");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1830
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1831
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1832
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1833
  enc_class Verify_FPU_For_Leaf %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1834
    if( VerifyFPU ) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1835
      MacroAssembler masm(&cbuf);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1836
      masm.verify_FPU( -3, "Returning from Runtime Leaf call");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1837
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1838
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1839
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1840
  enc_class Java_To_Runtime (method meth) %{    // CALL Java_To_Runtime, Java_To_Runtime_Leaf
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1841
    // This is the instruction starting address for relocation info.
6418
6671edbd230e 6978355: renaming for 6961697
twisti
parents: 6272
diff changeset
  1842
    cbuf.set_insts_mark();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1843
    $$$emit8$primary;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1844
    // CALL directly to the runtime
6418
6671edbd230e 6978355: renaming for 6961697
twisti
parents: 6272
diff changeset
  1845
    emit_d32_reloc(cbuf, ($meth$$method - (int)(cbuf.insts_end()) - 4),
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1846
                runtime_call_Relocation::spec(), RELOC_IMM32 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1847
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1848
    if (UseSSE >= 2) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1849
      MacroAssembler _masm(&cbuf);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1850
      BasicType rt = tf()->return_type();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1851
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1852
      if ((rt == T_FLOAT || rt == T_DOUBLE) && !return_value_is_used()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1853
        // A C runtime call where the return value is unused.  In SSE2+
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1854
        // mode the result needs to be removed from the FPU stack.  It's
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1855
        // likely that this function call could be removed by the
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1856
        // optimizer if the C function is a pure function.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1857
        __ ffree(0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1858
      } else if (rt == T_FLOAT) {
1066
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  1859
        __ lea(rsp, Address(rsp, -4));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1860
        __ fstp_s(Address(rsp, 0));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1861
        __ movflt(xmm0, Address(rsp, 0));
1066
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  1862
        __ lea(rsp, Address(rsp,  4));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1863
      } else if (rt == T_DOUBLE) {
1066
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  1864
        __ lea(rsp, Address(rsp, -8));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1865
        __ fstp_d(Address(rsp, 0));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1866
        __ movdbl(xmm0, Address(rsp, 0));
1066
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  1867
        __ lea(rsp, Address(rsp,  8));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1868
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1869
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1870
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1871
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1872
16624
9dbd4b210bf9 8011102: Clear AVX registers after return from JNI call
kvn
parents: 15242
diff changeset
  1873
  enc_class pre_call_resets %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1874
    // If method sets FPU control word restore it here
6418
6671edbd230e 6978355: renaming for 6961697
twisti
parents: 6272
diff changeset
  1875
    debug_only(int off0 = cbuf.insts_size());
16624
9dbd4b210bf9 8011102: Clear AVX registers after return from JNI call
kvn
parents: 15242
diff changeset
  1876
    if (ra_->C->in_24_bit_fp_mode()) {
9dbd4b210bf9 8011102: Clear AVX registers after return from JNI call
kvn
parents: 15242
diff changeset
  1877
      MacroAssembler _masm(&cbuf);
9dbd4b210bf9 8011102: Clear AVX registers after return from JNI call
kvn
parents: 15242
diff changeset
  1878
      __ fldcw(ExternalAddress(StubRoutines::addr_fpu_cntrl_wrd_std()));
9dbd4b210bf9 8011102: Clear AVX registers after return from JNI call
kvn
parents: 15242
diff changeset
  1879
    }
9dbd4b210bf9 8011102: Clear AVX registers after return from JNI call
kvn
parents: 15242
diff changeset
  1880
    if (ra_->C->max_vector_size() > 16) {
9dbd4b210bf9 8011102: Clear AVX registers after return from JNI call
kvn
parents: 15242
diff changeset
  1881
      // Clear upper bits of YMM registers when current compiled code uses
9dbd4b210bf9 8011102: Clear AVX registers after return from JNI call
kvn
parents: 15242
diff changeset
  1882
      // wide vectors to avoid AVX <-> SSE transition penalty during call.
9dbd4b210bf9 8011102: Clear AVX registers after return from JNI call
kvn
parents: 15242
diff changeset
  1883
      MacroAssembler _masm(&cbuf);
9dbd4b210bf9 8011102: Clear AVX registers after return from JNI call
kvn
parents: 15242
diff changeset
  1884
      __ vzeroupper();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1885
    }
6418
6671edbd230e 6978355: renaming for 6961697
twisti
parents: 6272
diff changeset
  1886
    debug_only(int off1 = cbuf.insts_size());
16624
9dbd4b210bf9 8011102: Clear AVX registers after return from JNI call
kvn
parents: 15242
diff changeset
  1887
    assert(off1 - off0 == pre_call_resets_size(), "correct size prediction");
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1888
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1889
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1890
  enc_class post_call_FPU %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1891
    // If method sets FPU control word do it here also
16624
9dbd4b210bf9 8011102: Clear AVX registers after return from JNI call
kvn
parents: 15242
diff changeset
  1892
    if (Compile::current()->in_24_bit_fp_mode()) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1893
      MacroAssembler masm(&cbuf);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1894
      masm.fldcw(ExternalAddress(StubRoutines::addr_fpu_cntrl_wrd_24()));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1895
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1896
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1897
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1898
  enc_class Java_Static_Call (method meth) %{    // JAVA STATIC CALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1899
    // CALL to fixup routine.  Fixup routine uses ScopeDesc info to determine
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1900
    // who we intended to call.
6418
6671edbd230e 6978355: renaming for 6961697
twisti
parents: 6272
diff changeset
  1901
    cbuf.set_insts_mark();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1902
    $$$emit8$primary;
16624
9dbd4b210bf9 8011102: Clear AVX registers after return from JNI call
kvn
parents: 15242
diff changeset
  1903
    if (!_method) {
6418
6671edbd230e 6978355: renaming for 6961697
twisti
parents: 6272
diff changeset
  1904
      emit_d32_reloc(cbuf, ($meth$$method - (int)(cbuf.insts_end()) - 4),
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1905
                     runtime_call_Relocation::spec(), RELOC_IMM32 );
16624
9dbd4b210bf9 8011102: Clear AVX registers after return from JNI call
kvn
parents: 15242
diff changeset
  1906
    } else if (_optimized_virtual) {
6418
6671edbd230e 6978355: renaming for 6961697
twisti
parents: 6272
diff changeset
  1907
      emit_d32_reloc(cbuf, ($meth$$method - (int)(cbuf.insts_end()) - 4),
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1908
                     opt_virtual_call_Relocation::spec(), RELOC_IMM32 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1909
    } else {
6418
6671edbd230e 6978355: renaming for 6961697
twisti
parents: 6272
diff changeset
  1910
      emit_d32_reloc(cbuf, ($meth$$method - (int)(cbuf.insts_end()) - 4),
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1911
                     static_call_Relocation::spec(), RELOC_IMM32 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1912
    }
17094
29c4955396d2 8003853: specify offset of IC load in java_to_interp stub
dlong
parents: 16624
diff changeset
  1913
    if (_method) {  // Emit stub for static call.
32082
2a3323e25de1 8130309: Need to bailout cleanly if creation of stubs fails when codecache is out of space
thartmann
parents: 31047
diff changeset
  1914
      address stub = CompiledStaticCall::emit_to_interp_stub(cbuf);
2a3323e25de1 8130309: Need to bailout cleanly if creation of stubs fails when codecache is out of space
thartmann
parents: 31047
diff changeset
  1915
      if (stub == NULL) {
2a3323e25de1 8130309: Need to bailout cleanly if creation of stubs fails when codecache is out of space
thartmann
parents: 31047
diff changeset
  1916
        ciEnv::current()->record_failure("CodeCache is full");
2a3323e25de1 8130309: Need to bailout cleanly if creation of stubs fails when codecache is out of space
thartmann
parents: 31047
diff changeset
  1917
        return;
2a3323e25de1 8130309: Need to bailout cleanly if creation of stubs fails when codecache is out of space
thartmann
parents: 31047
diff changeset
  1918
      } 
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1919
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1920
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1921
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1922
  enc_class Java_Dynamic_Call (method meth) %{    // JAVA DYNAMIC CALL
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13485
diff changeset
  1923
    MacroAssembler _masm(&cbuf);
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13485
diff changeset
  1924
    __ ic_call((address)$meth$$method);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1925
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1926
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1927
  enc_class Java_Compiled_Call (method meth) %{    // JAVA COMPILED CALL
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13485
diff changeset
  1928
    int disp = in_bytes(Method::from_compiled_offset());
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1929
    assert( -128 <= disp && disp <= 127, "compiled_code_offset isn't small");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1930
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13485
diff changeset
  1931
    // CALL *[EAX+in_bytes(Method::from_compiled_code_entry_point_offset())]
6418
6671edbd230e 6978355: renaming for 6961697
twisti
parents: 6272
diff changeset
  1932
    cbuf.set_insts_mark();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1933
    $$$emit8$primary;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1934
    emit_rm(cbuf, 0x01, $secondary, EAX_enc );  // R/M byte
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1935
    emit_d8(cbuf, disp);             // Displacement
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1936
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1937
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1938
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1939
//   Following encoding is no longer used, but may be restored if calling
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1940
//   convention changes significantly.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1941
//   Became: Xor_Reg(EBP), Java_To_Runtime( labl )
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1942
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1943
//   enc_class Java_Interpreter_Call (label labl) %{    // JAVA INTERPRETER CALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1944
//     // int ic_reg     = Matcher::inline_cache_reg();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1945
//     // int ic_encode  = Matcher::_regEncode[ic_reg];
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1946
//     // int imo_reg    = Matcher::interpreter_method_oop_reg();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1947
//     // int imo_encode = Matcher::_regEncode[imo_reg];
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1948
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1949
//     // // Interpreter expects method_oop in EBX, currently a callee-saved register,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1950
//     // // so we load it immediately before the call
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1951
//     // emit_opcode(cbuf, 0x8B);                     // MOV    imo_reg,ic_reg  # method_oop
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1952
//     // emit_rm(cbuf, 0x03, imo_encode, ic_encode ); // R/M byte
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1953
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1954
//     // xor rbp,ebp
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1955
//     emit_opcode(cbuf, 0x33);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1956
//     emit_rm(cbuf, 0x3, EBP_enc, EBP_enc);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1957
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1958
//     // CALL to interpreter.
6418
6671edbd230e 6978355: renaming for 6961697
twisti
parents: 6272
diff changeset
  1959
//     cbuf.set_insts_mark();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1960
//     $$$emit8$primary;
6418
6671edbd230e 6978355: renaming for 6961697
twisti
parents: 6272
diff changeset
  1961
//     emit_d32_reloc(cbuf, ($labl$$label - (int)(cbuf.insts_end()) - 4),
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1962
//                 runtime_call_Relocation::spec(), RELOC_IMM32 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1963
//   %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1964
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1965
  enc_class RegOpcImm (rRegI dst, immI8 shift) %{    // SHL, SAR, SHR
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1966
    $$$emit8$primary;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1967
    emit_rm(cbuf, 0x3, $secondary, $dst$$reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1968
    $$$emit8$shift$$constant;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1969
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1970
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1971
  enc_class LdImmI (rRegI dst, immI src) %{    // Load Immediate
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1972
    // Load immediate does not have a zero or sign extended version
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1973
    // for 8-bit immediates
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1974
    emit_opcode(cbuf, 0xB8 + $dst$$reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1975
    $$$emit32$src$$constant;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1976
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1977
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  1978
  enc_class LdImmP (rRegI dst, immI src) %{    // Load Immediate
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1979
    // Load immediate does not have a zero or sign extended version
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1980
    // for 8-bit immediates
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1981
    emit_opcode(cbuf, $primary + $dst$$reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1982
    $$$emit32$src$$constant;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1983
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1984
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1985
  enc_class LdImmL_Lo( eRegL dst, immL src) %{    // Load Immediate
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1986
    // Load immediate does not have a zero or sign extended version
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1987
    // for 8-bit immediates
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1988
    int dst_enc = $dst$$reg;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1989
    int src_con = $src$$constant & 0x0FFFFFFFFL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1990
    if (src_con == 0) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1991
      // xor dst, dst
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1992
      emit_opcode(cbuf, 0x33);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1993
      emit_rm(cbuf, 0x3, dst_enc, dst_enc);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1994
    } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1995
      emit_opcode(cbuf, $primary + dst_enc);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1996
      emit_d32(cbuf, src_con);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1997
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1998
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1999
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2000
  enc_class LdImmL_Hi( eRegL dst, immL src) %{    // Load Immediate
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2001
    // Load immediate does not have a zero or sign extended version
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2002
    // for 8-bit immediates
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2003
    int dst_enc = $dst$$reg + 2;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2004
    int src_con = ((julong)($src$$constant)) >> 32;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2005
    if (src_con == 0) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2006
      // xor dst, dst
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2007
      emit_opcode(cbuf, 0x33);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2008
      emit_rm(cbuf, 0x3, dst_enc, dst_enc);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2009
    } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2010
      emit_opcode(cbuf, $primary + dst_enc);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2011
      emit_d32(cbuf, src_con);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2012
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2013
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2014
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2015
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2016
  // Encode a reg-reg copy.  If it is useless, then empty encoding.
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  2017
  enc_class enc_Copy( rRegI dst, rRegI src ) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2018
    encode_Copy( cbuf, $dst$$reg, $src$$reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2019
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2020
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  2021
  enc_class enc_CopyL_Lo( rRegI dst, eRegL src ) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2022
    encode_Copy( cbuf, $dst$$reg, $src$$reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2023
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2024
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  2025
  enc_class RegReg (rRegI dst, rRegI src) %{    // RegReg(Many)
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2026
    emit_rm(cbuf, 0x3, $dst$$reg, $src$$reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2027
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2028
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2029
  enc_class RegReg_Lo(eRegL dst, eRegL src) %{    // RegReg(Many)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2030
    $$$emit8$primary;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2031
    emit_rm(cbuf, 0x3, $dst$$reg, $src$$reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2032
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2033
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2034
  enc_class RegReg_Hi(eRegL dst, eRegL src) %{    // RegReg(Many)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2035
    $$$emit8$secondary;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2036
    emit_rm(cbuf, 0x3, HIGH_FROM_LOW($dst$$reg), HIGH_FROM_LOW($src$$reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2037
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2038
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2039
  enc_class RegReg_Lo2(eRegL dst, eRegL src) %{    // RegReg(Many)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2040
    emit_rm(cbuf, 0x3, $dst$$reg, $src$$reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2041
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2042
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2043
  enc_class RegReg_Hi2(eRegL dst, eRegL src) %{    // RegReg(Many)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2044
    emit_rm(cbuf, 0x3, HIGH_FROM_LOW($dst$$reg), HIGH_FROM_LOW($src$$reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2045
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2046
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  2047
  enc_class RegReg_HiLo( eRegL src, rRegI dst ) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2048
    emit_rm(cbuf, 0x3, $dst$$reg, HIGH_FROM_LOW($src$$reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2049
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2050
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2051
  enc_class Con32 (immI src) %{    // Con32(storeImmI)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2052
    // Output immediate
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2053
    $$$emit32$src$$constant;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2054
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2055
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  2056
  enc_class Con32FPR_as_bits(immFPR src) %{        // storeF_imm
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2057
    // Output Float immediate bits
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2058
    jfloat jf = $src$$constant;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2059
    int    jf_as_bits = jint_cast( jf );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2060
    emit_d32(cbuf, jf_as_bits);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2061
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2062
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  2063
  enc_class Con32F_as_bits(immF src) %{      // storeX_imm
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2064
    // Output Float immediate bits
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2065
    jfloat jf = $src$$constant;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2066
    int    jf_as_bits = jint_cast( jf );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2067
    emit_d32(cbuf, jf_as_bits);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2068
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2069
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2070
  enc_class Con16 (immI src) %{    // Con16(storeImmI)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2071
    // Output immediate
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2072
    $$$emit16$src$$constant;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2073
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2074
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2075
  enc_class Con_d32(immI src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2076
    emit_d32(cbuf,$src$$constant);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2077
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2078
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2079
  enc_class conmemref (eRegP t1) %{    // Con32(storeImmI)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2080
    // Output immediate memory reference
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2081
    emit_rm(cbuf, 0x00, $t1$$reg, 0x05 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2082
    emit_d32(cbuf, 0x00);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2083
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2084
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2085
  enc_class lock_prefix( ) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2086
    if( os::is_MP() )
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2087
      emit_opcode(cbuf,0xF0);         // [Lock]
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2088
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2089
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2090
  // Cmp-xchg long value.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2091
  // Note: we need to swap rbx, and rcx before and after the
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2092
  //       cmpxchg8 instruction because the instruction uses
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2093
  //       rcx as the high order word of the new value to store but
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2094
  //       our register encoding uses rbx,.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2095
  enc_class enc_cmpxchg8(eSIRegP mem_ptr) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2096
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2097
    // XCHG  rbx,ecx
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2098
    emit_opcode(cbuf,0x87);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2099
    emit_opcode(cbuf,0xD9);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2100
    // [Lock]
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2101
    if( os::is_MP() )
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2102
      emit_opcode(cbuf,0xF0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2103
    // CMPXCHG8 [Eptr]
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2104
    emit_opcode(cbuf,0x0F);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2105
    emit_opcode(cbuf,0xC7);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2106
    emit_rm( cbuf, 0x0, 1, $mem_ptr$$reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2107
    // XCHG  rbx,ecx
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2108
    emit_opcode(cbuf,0x87);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2109
    emit_opcode(cbuf,0xD9);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2110
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2111
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2112
  enc_class enc_cmpxchg(eSIRegP mem_ptr) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2113
    // [Lock]
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2114
    if( os::is_MP() )
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2115
      emit_opcode(cbuf,0xF0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2116
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2117
    // CMPXCHG [Eptr]
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2118
    emit_opcode(cbuf,0x0F);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2119
    emit_opcode(cbuf,0xB1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2120
    emit_rm( cbuf, 0x0, 1, $mem_ptr$$reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2121
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2122
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2123
  enc_class enc_flags_ne_to_boolean( iRegI res ) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2124
    int res_encoding = $res$$reg;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2125
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2126
    // MOV  res,0
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2127
    emit_opcode( cbuf, 0xB8 + res_encoding);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2128
    emit_d32( cbuf, 0 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2129
    // JNE,s  fail
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2130
    emit_opcode(cbuf,0x75);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2131
    emit_d8(cbuf, 5 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2132
    // MOV  res,1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2133
    emit_opcode( cbuf, 0xB8 + res_encoding);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2134
    emit_d32( cbuf, 1 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2135
    // fail:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2136
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2137
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2138
  enc_class set_instruction_start( ) %{
6418
6671edbd230e 6978355: renaming for 6961697
twisti
parents: 6272
diff changeset
  2139
    cbuf.set_insts_mark();            // Mark start of opcode for reloc info in mem operand
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2140
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2141
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  2142
  enc_class RegMem (rRegI ereg, memory mem) %{    // emit_reg_mem
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2143
    int reg_encoding = $ereg$$reg;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2144
    int base  = $mem$$base;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2145
    int index = $mem$$index;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2146
    int scale = $mem$$scale;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2147
    int displace = $mem$$disp;
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13485
diff changeset
  2148
    relocInfo::relocType disp_reloc = $mem->disp_reloc();
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13485
diff changeset
  2149
    encode_RegMem(cbuf, reg_encoding, base, index, scale, displace, disp_reloc);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2150
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2151
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2152
  enc_class RegMem_Hi(eRegL ereg, memory mem) %{    // emit_reg_mem
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2153
    int reg_encoding = HIGH_FROM_LOW($ereg$$reg);  // Hi register of pair, computed from lo
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2154
    int base  = $mem$$base;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2155
    int index = $mem$$index;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2156
    int scale = $mem$$scale;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2157
    int displace = $mem$$disp + 4;      // Offset is 4 further in memory
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13485
diff changeset
  2158
    assert( $mem->disp_reloc() == relocInfo::none, "Cannot add 4 to oop" );
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13485
diff changeset
  2159
    encode_RegMem(cbuf, reg_encoding, base, index, scale, displace, relocInfo::none);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2160
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2161
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2162
  enc_class move_long_small_shift( eRegL dst, immI_1_31 cnt ) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2163
    int r1, r2;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2164
    if( $tertiary == 0xA4 ) { r1 = $dst$$reg;  r2 = HIGH_FROM_LOW($dst$$reg); }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2165
    else                    { r2 = $dst$$reg;  r1 = HIGH_FROM_LOW($dst$$reg); }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2166
    emit_opcode(cbuf,0x0F);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2167
    emit_opcode(cbuf,$tertiary);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2168
    emit_rm(cbuf, 0x3, r1, r2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2169
    emit_d8(cbuf,$cnt$$constant);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2170
    emit_d8(cbuf,$primary);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2171
    emit_rm(cbuf, 0x3, $secondary, r1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2172
    emit_d8(cbuf,$cnt$$constant);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2173
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2174
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2175
  enc_class move_long_big_shift_sign( eRegL dst, immI_32_63 cnt ) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2176
    emit_opcode( cbuf, 0x8B ); // Move
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2177
    emit_rm(cbuf, 0x3, $dst$$reg, HIGH_FROM_LOW($dst$$reg));
7115
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  2178
    if( $cnt$$constant > 32 ) { // Shift, if not by zero
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  2179
      emit_d8(cbuf,$primary);
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  2180
      emit_rm(cbuf, 0x3, $secondary, $dst$$reg);
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  2181
      emit_d8(cbuf,$cnt$$constant-32);
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  2182
    }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2183
    emit_d8(cbuf,$primary);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2184
    emit_rm(cbuf, 0x3, $secondary, HIGH_FROM_LOW($dst$$reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2185
    emit_d8(cbuf,31);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2186
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2187
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2188
  enc_class move_long_big_shift_clr( eRegL dst, immI_32_63 cnt ) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2189
    int r1, r2;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2190
    if( $secondary == 0x5 ) { r1 = $dst$$reg;  r2 = HIGH_FROM_LOW($dst$$reg); }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2191
    else                    { r2 = $dst$$reg;  r1 = HIGH_FROM_LOW($dst$$reg); }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2192
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2193
    emit_opcode( cbuf, 0x8B ); // Move r1,r2
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2194
    emit_rm(cbuf, 0x3, r1, r2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2195
    if( $cnt$$constant > 32 ) { // Shift, if not by zero
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2196
      emit_opcode(cbuf,$primary);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2197
      emit_rm(cbuf, 0x3, $secondary, r1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2198
      emit_d8(cbuf,$cnt$$constant-32);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2199
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2200
    emit_opcode(cbuf,0x33);  // XOR r2,r2
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2201
    emit_rm(cbuf, 0x3, r2, r2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2202
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2203
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2204
  // Clone of RegMem but accepts an extra parameter to access each
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2205
  // half of a double in memory; it never needs relocation info.
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  2206
  enc_class Mov_MemD_half_to_Reg (immI opcode, memory mem, immI disp_for_half, rRegI rm_reg) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2207
    emit_opcode(cbuf,$opcode$$constant);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2208
    int reg_encoding = $rm_reg$$reg;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2209
    int base     = $mem$$base;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2210
    int index    = $mem$$index;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2211
    int scale    = $mem$$scale;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2212
    int displace = $mem$$disp + $disp_for_half$$constant;
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13485
diff changeset
  2213
    relocInfo::relocType disp_reloc = relocInfo::none;
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13485
diff changeset
  2214
    encode_RegMem(cbuf, reg_encoding, base, index, scale, displace, disp_reloc);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2215
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2216
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2217
  // !!!!! Special Custom Code used by MemMove, and stack access instructions !!!!!
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2218
  //
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2219
  // Clone of RegMem except the RM-byte's reg/opcode field is an ADLC-time constant
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2220
  // and it never needs relocation information.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2221
  // Frequently used to move data between FPU's Stack Top and memory.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2222
  enc_class RMopc_Mem_no_oop (immI rm_opcode, memory mem) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2223
    int rm_byte_opcode = $rm_opcode$$constant;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2224
    int base     = $mem$$base;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2225
    int index    = $mem$$index;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2226
    int scale    = $mem$$scale;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2227
    int displace = $mem$$disp;
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13485
diff changeset
  2228
    assert( $mem->disp_reloc() == relocInfo::none, "No oops here because no reloc info allowed" );
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13485
diff changeset
  2229
    encode_RegMem(cbuf, rm_byte_opcode, base, index, scale, displace, relocInfo::none);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2230
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2231
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2232
  enc_class RMopc_Mem (immI rm_opcode, memory mem) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2233
    int rm_byte_opcode = $rm_opcode$$constant;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2234
    int base     = $mem$$base;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2235
    int index    = $mem$$index;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2236
    int scale    = $mem$$scale;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2237
    int displace = $mem$$disp;
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13485
diff changeset
  2238
    relocInfo::relocType disp_reloc = $mem->disp_reloc(); // disp-as-oop when working with static globals
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13485
diff changeset
  2239
    encode_RegMem(cbuf, rm_byte_opcode, base, index, scale, displace, disp_reloc);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2240
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2241
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  2242
  enc_class RegLea (rRegI dst, rRegI src0, immI src1 ) %{    // emit_reg_lea
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2243
    int reg_encoding = $dst$$reg;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2244
    int base         = $src0$$reg;      // 0xFFFFFFFF indicates no base
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2245
    int index        = 0x04;            // 0x04 indicates no index
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2246
    int scale        = 0x00;            // 0x00 indicates no scale
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2247
    int displace     = $src1$$constant; // 0x00 indicates no displacement
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13485
diff changeset
  2248
    relocInfo::relocType disp_reloc = relocInfo::none;
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13485
diff changeset
  2249
    encode_RegMem(cbuf, reg_encoding, base, index, scale, displace, disp_reloc);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2250
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2251
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  2252
  enc_class min_enc (rRegI dst, rRegI src) %{    // MIN
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2253
    // Compare dst,src
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2254
    emit_opcode(cbuf,0x3B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2255
    emit_rm(cbuf, 0x3, $dst$$reg, $src$$reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2256
    // jmp dst < src around move
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2257
    emit_opcode(cbuf,0x7C);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2258
    emit_d8(cbuf,2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2259
    // move dst,src
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2260
    emit_opcode(cbuf,0x8B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2261
    emit_rm(cbuf, 0x3, $dst$$reg, $src$$reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2262
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2263
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  2264
  enc_class max_enc (rRegI dst, rRegI src) %{    // MAX
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2265
    // Compare dst,src
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2266
    emit_opcode(cbuf,0x3B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2267
    emit_rm(cbuf, 0x3, $dst$$reg, $src$$reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2268
    // jmp dst > src around move
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2269
    emit_opcode(cbuf,0x7F);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2270
    emit_d8(cbuf,2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2271
    // move dst,src
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2272
    emit_opcode(cbuf,0x8B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2273
    emit_rm(cbuf, 0x3, $dst$$reg, $src$$reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2274
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2275
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  2276
  enc_class enc_FPR_store(memory mem, regDPR src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2277
    // If src is FPR1, we can just FST to store it.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2278
    // Else we need to FLD it to FPR1, then FSTP to store/pop it.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2279
    int reg_encoding = 0x2; // Just store
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2280
    int base  = $mem$$base;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2281
    int index = $mem$$index;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2282
    int scale = $mem$$scale;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2283
    int displace = $mem$$disp;
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13485
diff changeset
  2284
    relocInfo::relocType disp_reloc = $mem->disp_reloc(); // disp-as-oop when working with static globals
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2285
    if( $src$$reg != FPR1L_enc ) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2286
      reg_encoding = 0x3;  // Store & pop
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2287
      emit_opcode( cbuf, 0xD9 ); // FLD (i.e., push it)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2288
      emit_d8( cbuf, 0xC0-1+$src$$reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2289
    }
6418
6671edbd230e 6978355: renaming for 6961697
twisti
parents: 6272
diff changeset
  2290
    cbuf.set_insts_mark();       // Mark start of opcode for reloc info in mem operand
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2291
    emit_opcode(cbuf,$primary);
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13485
diff changeset
  2292
    encode_RegMem(cbuf, reg_encoding, base, index, scale, displace, disp_reloc);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2293
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2294
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  2295
  enc_class neg_reg(rRegI dst) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2296
    // NEG $dst
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2297
    emit_opcode(cbuf,0xF7);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2298
    emit_rm(cbuf, 0x3, 0x03, $dst$$reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2299
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2300
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2301
  enc_class setLT_reg(eCXRegI dst) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2302
    // SETLT $dst
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2303
    emit_opcode(cbuf,0x0F);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2304
    emit_opcode(cbuf,0x9C);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2305
    emit_rm( cbuf, 0x3, 0x4, $dst$$reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2306
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2307
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2308
  enc_class enc_cmpLTP(ncxRegI p, ncxRegI q, ncxRegI y, eCXRegI tmp) %{    // cadd_cmpLT
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2309
    int tmpReg = $tmp$$reg;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2310
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2311
    // SUB $p,$q
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2312
    emit_opcode(cbuf,0x2B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2313
    emit_rm(cbuf, 0x3, $p$$reg, $q$$reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2314
    // SBB $tmp,$tmp
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2315
    emit_opcode(cbuf,0x1B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2316
    emit_rm(cbuf, 0x3, tmpReg, tmpReg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2317
    // AND $tmp,$y
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2318
    emit_opcode(cbuf,0x23);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2319
    emit_rm(cbuf, 0x3, tmpReg, $y$$reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2320
    // ADD $p,$tmp
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2321
    emit_opcode(cbuf,0x03);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2322
    emit_rm(cbuf, 0x3, $p$$reg, tmpReg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2323
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2324
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2325
  enc_class shift_left_long( eRegL dst, eCXRegI shift ) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2326
    // TEST shift,32
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2327
    emit_opcode(cbuf,0xF7);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2328
    emit_rm(cbuf, 0x3, 0, ECX_enc);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2329
    emit_d32(cbuf,0x20);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2330
    // JEQ,s small
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2331
    emit_opcode(cbuf, 0x74);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2332
    emit_d8(cbuf, 0x04);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2333
    // MOV    $dst.hi,$dst.lo
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2334
    emit_opcode( cbuf, 0x8B );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2335
    emit_rm(cbuf, 0x3, HIGH_FROM_LOW($dst$$reg), $dst$$reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2336
    // CLR    $dst.lo
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2337
    emit_opcode(cbuf, 0x33);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2338
    emit_rm(cbuf, 0x3, $dst$$reg, $dst$$reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2339
// small:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2340
    // SHLD   $dst.hi,$dst.lo,$shift
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2341
    emit_opcode(cbuf,0x0F);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2342
    emit_opcode(cbuf,0xA5);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2343
    emit_rm(cbuf, 0x3, $dst$$reg, HIGH_FROM_LOW($dst$$reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2344
    // SHL    $dst.lo,$shift"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2345
    emit_opcode(cbuf,0xD3);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2346
    emit_rm(cbuf, 0x3, 0x4, $dst$$reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2347
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2348
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2349
  enc_class shift_right_long( eRegL dst, eCXRegI shift ) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2350
    // TEST shift,32
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2351
    emit_opcode(cbuf,0xF7);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2352
    emit_rm(cbuf, 0x3, 0, ECX_enc);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2353
    emit_d32(cbuf,0x20);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2354
    // JEQ,s small
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2355
    emit_opcode(cbuf, 0x74);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2356
    emit_d8(cbuf, 0x04);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2357
    // MOV    $dst.lo,$dst.hi
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2358
    emit_opcode( cbuf, 0x8B );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2359
    emit_rm(cbuf, 0x3, $dst$$reg, HIGH_FROM_LOW($dst$$reg) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2360
    // CLR    $dst.hi
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2361
    emit_opcode(cbuf, 0x33);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2362
    emit_rm(cbuf, 0x3, HIGH_FROM_LOW($dst$$reg), HIGH_FROM_LOW($dst$$reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2363
// small:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2364
    // SHRD   $dst.lo,$dst.hi,$shift
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2365
    emit_opcode(cbuf,0x0F);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2366
    emit_opcode(cbuf,0xAD);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2367
    emit_rm(cbuf, 0x3, HIGH_FROM_LOW($dst$$reg), $dst$$reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2368
    // SHR    $dst.hi,$shift"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2369
    emit_opcode(cbuf,0xD3);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2370
    emit_rm(cbuf, 0x3, 0x5, HIGH_FROM_LOW($dst$$reg) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2371
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2372
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2373
  enc_class shift_right_arith_long( eRegL dst, eCXRegI shift ) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2374
    // TEST shift,32
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2375
    emit_opcode(cbuf,0xF7);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2376
    emit_rm(cbuf, 0x3, 0, ECX_enc);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2377
    emit_d32(cbuf,0x20);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2378
    // JEQ,s small
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2379
    emit_opcode(cbuf, 0x74);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2380
    emit_d8(cbuf, 0x05);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2381
    // MOV    $dst.lo,$dst.hi
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2382
    emit_opcode( cbuf, 0x8B );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2383
    emit_rm(cbuf, 0x3, $dst$$reg, HIGH_FROM_LOW($dst$$reg) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2384
    // SAR    $dst.hi,31
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2385
    emit_opcode(cbuf, 0xC1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2386
    emit_rm(cbuf, 0x3, 7, HIGH_FROM_LOW($dst$$reg) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2387
    emit_d8(cbuf, 0x1F );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2388
// small:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2389
    // SHRD   $dst.lo,$dst.hi,$shift
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2390
    emit_opcode(cbuf,0x0F);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2391
    emit_opcode(cbuf,0xAD);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2392
    emit_rm(cbuf, 0x3, HIGH_FROM_LOW($dst$$reg), $dst$$reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2393
    // SAR    $dst.hi,$shift"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2394
    emit_opcode(cbuf,0xD3);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2395
    emit_rm(cbuf, 0x3, 0x7, HIGH_FROM_LOW($dst$$reg) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2396
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2397
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2398
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2399
  // ----------------- Encodings for floating point unit -----------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2400
  // May leave result in FPU-TOS or FPU reg depending on opcodes
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  2401
  enc_class OpcReg_FPR(regFPR src) %{    // FMUL, FDIV
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2402
    $$$emit8$primary;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2403
    emit_rm(cbuf, 0x3, $secondary, $src$$reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2404
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2405
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2406
  // Pop argument in FPR0 with FSTP ST(0)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2407
  enc_class PopFPU() %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2408
    emit_opcode( cbuf, 0xDD );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2409
    emit_d8( cbuf, 0xD8 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2410
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2411
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2412
  // !!!!! equivalent to Pop_Reg_F
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  2413
  enc_class Pop_Reg_DPR( regDPR dst ) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2414
    emit_opcode( cbuf, 0xDD );           // FSTP   ST(i)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2415
    emit_d8( cbuf, 0xD8+$dst$$reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2416
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2417
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  2418
  enc_class Push_Reg_DPR( regDPR dst ) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2419
    emit_opcode( cbuf, 0xD9 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2420
    emit_d8( cbuf, 0xC0-1+$dst$$reg );   // FLD ST(i-1)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2421
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2422
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  2423
  enc_class strictfp_bias1( regDPR dst ) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2424
    emit_opcode( cbuf, 0xDB );           // FLD m80real
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2425
    emit_opcode( cbuf, 0x2D );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2426
    emit_d32( cbuf, (int)StubRoutines::addr_fpu_subnormal_bias1() );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2427
    emit_opcode( cbuf, 0xDE );           // FMULP ST(dst), ST0
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2428
    emit_opcode( cbuf, 0xC8+$dst$$reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2429
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2430
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  2431
  enc_class strictfp_bias2( regDPR dst ) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2432
    emit_opcode( cbuf, 0xDB );           // FLD m80real
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2433
    emit_opcode( cbuf, 0x2D );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2434
    emit_d32( cbuf, (int)StubRoutines::addr_fpu_subnormal_bias2() );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2435
    emit_opcode( cbuf, 0xDE );           // FMULP ST(dst), ST0
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2436
    emit_opcode( cbuf, 0xC8+$dst$$reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2437
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2438
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2439
  // Special case for moving an integer register to a stack slot.
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  2440
  enc_class OpcPRegSS( stackSlotI dst, rRegI src ) %{ // RegSS
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2441
    store_to_stackslot( cbuf, $primary, $src$$reg, $dst$$disp );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2442
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2443
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2444
  // Special case for moving a register to a stack slot.
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  2445
  enc_class RegSS( stackSlotI dst, rRegI src ) %{ // RegSS
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2446
    // Opcode already emitted
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2447
    emit_rm( cbuf, 0x02, $src$$reg, ESP_enc );   // R/M byte
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2448
    emit_rm( cbuf, 0x00, ESP_enc, ESP_enc);          // SIB byte
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2449
    emit_d32(cbuf, $dst$$disp);   // Displacement
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2450
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2451
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2452
  // Push the integer in stackSlot 'src' onto FP-stack
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2453
  enc_class Push_Mem_I( memory src ) %{    // FILD   [ESP+src]
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2454
    store_to_stackslot( cbuf, $primary, $secondary, $src$$disp );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2455
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2456
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2457
  // Push FPU's TOS float to a stack-slot, and pop FPU-stack
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  2458
  enc_class Pop_Mem_FPR( stackSlotF dst ) %{ // FSTP_S [ESP+dst]
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2459
    store_to_stackslot( cbuf, 0xD9, 0x03, $dst$$disp );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2460
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2461
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2462
  // Same as Pop_Mem_F except for opcode
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2463
  // Push FPU's TOS double to a stack-slot, and pop FPU-stack
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  2464
  enc_class Pop_Mem_DPR( stackSlotD dst ) %{ // FSTP_D [ESP+dst]
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2465
    store_to_stackslot( cbuf, 0xDD, 0x03, $dst$$disp );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2466
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2467
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  2468
  enc_class Pop_Reg_FPR( regFPR dst ) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2469
    emit_opcode( cbuf, 0xDD );           // FSTP   ST(i)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2470
    emit_d8( cbuf, 0xD8+$dst$$reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2471
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2472
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  2473
  enc_class Push_Reg_FPR( regFPR dst ) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2474
    emit_opcode( cbuf, 0xD9 );           // FLD    ST(i-1)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2475
    emit_d8( cbuf, 0xC0-1+$dst$$reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2476
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2477
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2478
  // Push FPU's float to a stack-slot, and pop FPU-stack
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  2479
  enc_class Pop_Mem_Reg_FPR( stackSlotF dst, regFPR src ) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2480
    int pop = 0x02;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2481
    if ($src$$reg != FPR1L_enc) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2482
      emit_opcode( cbuf, 0xD9 );         // FLD    ST(i-1)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2483
      emit_d8( cbuf, 0xC0-1+$src$$reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2484
      pop = 0x03;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2485
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2486
    store_to_stackslot( cbuf, 0xD9, pop, $dst$$disp ); // FST<P>_S  [ESP+dst]
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2487
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2488
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2489
  // Push FPU's double to a stack-slot, and pop FPU-stack
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  2490
  enc_class Pop_Mem_Reg_DPR( stackSlotD dst, regDPR src ) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2491
    int pop = 0x02;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2492
    if ($src$$reg != FPR1L_enc) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2493
      emit_opcode( cbuf, 0xD9 );         // FLD    ST(i-1)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2494
      emit_d8( cbuf, 0xC0-1+$src$$reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2495
      pop = 0x03;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2496
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2497
    store_to_stackslot( cbuf, 0xDD, pop, $dst$$disp ); // FST<P>_D  [ESP+dst]
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2498
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2499
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2500
  // Push FPU's double to a FPU-stack-slot, and pop FPU-stack
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  2501
  enc_class Pop_Reg_Reg_DPR( regDPR dst, regFPR src ) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2502
    int pop = 0xD0 - 1; // -1 since we skip FLD
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2503
    if ($src$$reg != FPR1L_enc) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2504
      emit_opcode( cbuf, 0xD9 );         // FLD    ST(src-1)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2505
      emit_d8( cbuf, 0xC0-1+$src$$reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2506
      pop = 0xD8;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2507
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2508
    emit_opcode( cbuf, 0xDD );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2509
    emit_d8( cbuf, pop+$dst$$reg );      // FST<P> ST(i)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2510
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2511
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2512
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  2513
  enc_class Push_Reg_Mod_DPR( regDPR dst, regDPR src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2514
    // load dst in FPR0
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2515
    emit_opcode( cbuf, 0xD9 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2516
    emit_d8( cbuf, 0xC0-1+$dst$$reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2517
    if ($src$$reg != FPR1L_enc) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2518
      // fincstp
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2519
      emit_opcode (cbuf, 0xD9);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2520
      emit_opcode (cbuf, 0xF7);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2521
      // swap src with FPR1:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2522
      // FXCH FPR1 with src
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2523
      emit_opcode(cbuf, 0xD9);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2524
      emit_d8(cbuf, 0xC8-1+$src$$reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2525
      // fdecstp
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2526
      emit_opcode (cbuf, 0xD9);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2527
      emit_opcode (cbuf, 0xF6);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2528
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2529
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2530
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  2531
  enc_class Push_ModD_encoding(regD src0, regD src1) %{
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  2532
    MacroAssembler _masm(&cbuf);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  2533
    __ subptr(rsp, 8);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  2534
    __ movdbl(Address(rsp, 0), $src1$$XMMRegister);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  2535
    __ fld_d(Address(rsp, 0));
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  2536
    __ movdbl(Address(rsp, 0), $src0$$XMMRegister);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  2537
    __ fld_d(Address(rsp, 0));
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  2538
  %}
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  2539
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  2540
  enc_class Push_ModF_encoding(regF src0, regF src1) %{
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  2541
    MacroAssembler _masm(&cbuf);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  2542
    __ subptr(rsp, 4);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  2543
    __ movflt(Address(rsp, 0), $src1$$XMMRegister);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  2544
    __ fld_s(Address(rsp, 0));
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  2545
    __ movflt(Address(rsp, 0), $src0$$XMMRegister);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  2546
    __ fld_s(Address(rsp, 0));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2547
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2548
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  2549
  enc_class Push_ResultD(regD dst) %{
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  2550
    MacroAssembler _masm(&cbuf);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  2551
    __ fstp_d(Address(rsp, 0));
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  2552
    __ movdbl($dst$$XMMRegister, Address(rsp, 0));
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  2553
    __ addptr(rsp, 8);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2554
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2555
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  2556
  enc_class Push_ResultF(regF dst, immI d8) %{
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  2557
    MacroAssembler _masm(&cbuf);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  2558
    __ fstp_s(Address(rsp, 0));
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  2559
    __ movflt($dst$$XMMRegister, Address(rsp, 0));
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  2560
    __ addptr(rsp, $d8$$constant);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2561
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2562
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  2563
  enc_class Push_SrcD(regD src) %{
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  2564
    MacroAssembler _masm(&cbuf);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  2565
    __ subptr(rsp, 8);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  2566
    __ movdbl(Address(rsp, 0), $src$$XMMRegister);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  2567
    __ fld_d(Address(rsp, 0));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2568
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2569
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2570
  enc_class push_stack_temp_qword() %{
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  2571
    MacroAssembler _masm(&cbuf);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  2572
    __ subptr(rsp, 8);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2573
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2574
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2575
  enc_class pop_stack_temp_qword() %{
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  2576
    MacroAssembler _masm(&cbuf);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  2577
    __ addptr(rsp, 8);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  2578
  %}
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  2579
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  2580
  enc_class push_xmm_to_fpr1(regD src) %{
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  2581
    MacroAssembler _masm(&cbuf);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  2582
    __ movdbl(Address(rsp, 0), $src$$XMMRegister);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  2583
    __ fld_d(Address(rsp, 0));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2584
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2585
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  2586
  enc_class Push_Result_Mod_DPR( regDPR src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2587
    if ($src$$reg != FPR1L_enc) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2588
      // fincstp
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2589
      emit_opcode (cbuf, 0xD9);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2590
      emit_opcode (cbuf, 0xF7);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2591
      // FXCH FPR1 with src
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2592
      emit_opcode(cbuf, 0xD9);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2593
      emit_d8(cbuf, 0xC8-1+$src$$reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2594
      // fdecstp
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2595
      emit_opcode (cbuf, 0xD9);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2596
      emit_opcode (cbuf, 0xF6);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2597
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2598
    // // following asm replaced with Pop_Reg_F or Pop_Mem_F
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2599
    // // FSTP   FPR$dst$$reg
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2600
    // emit_opcode( cbuf, 0xDD );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2601
    // emit_d8( cbuf, 0xD8+$dst$$reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2602
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2603
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2604
  enc_class fnstsw_sahf_skip_parity() %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2605
    // fnstsw ax
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2606
    emit_opcode( cbuf, 0xDF );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2607
    emit_opcode( cbuf, 0xE0 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2608
    // sahf
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2609
    emit_opcode( cbuf, 0x9E );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2610
    // jnp  ::skip
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2611
    emit_opcode( cbuf, 0x7B );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2612
    emit_opcode( cbuf, 0x05 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2613
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2614
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  2615
  enc_class emitModDPR() %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2616
    // fprem must be iterative
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2617
    // :: loop
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2618
    // fprem
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2619
    emit_opcode( cbuf, 0xD9 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2620
    emit_opcode( cbuf, 0xF8 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2621
    // wait
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2622
    emit_opcode( cbuf, 0x9b );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2623
    // fnstsw ax
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2624
    emit_opcode( cbuf, 0xDF );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2625
    emit_opcode( cbuf, 0xE0 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2626
    // sahf
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2627
    emit_opcode( cbuf, 0x9E );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2628
    // jp  ::loop
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2629
    emit_opcode( cbuf, 0x0F );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2630
    emit_opcode( cbuf, 0x8A );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2631
    emit_opcode( cbuf, 0xF4 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2632
    emit_opcode( cbuf, 0xFF );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2633
    emit_opcode( cbuf, 0xFF );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2634
    emit_opcode( cbuf, 0xFF );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2635
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2636
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2637
  enc_class fpu_flags() %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2638
    // fnstsw_ax
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2639
    emit_opcode( cbuf, 0xDF);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2640
    emit_opcode( cbuf, 0xE0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2641
    // test ax,0x0400
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2642
    emit_opcode( cbuf, 0x66 );   // operand-size prefix for 16-bit immediate
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2643
    emit_opcode( cbuf, 0xA9 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2644
    emit_d16   ( cbuf, 0x0400 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2645
    // // // This sequence works, but stalls for 12-16 cycles on PPro
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2646
    // // test rax,0x0400
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2647
    // emit_opcode( cbuf, 0xA9 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2648
    // emit_d32   ( cbuf, 0x00000400 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2649
    //
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2650
    // jz exit (no unordered comparison)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2651
    emit_opcode( cbuf, 0x74 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2652
    emit_d8    ( cbuf, 0x02 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2653
    // mov ah,1 - treat as LT case (set carry flag)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2654
    emit_opcode( cbuf, 0xB4 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2655
    emit_d8    ( cbuf, 0x01 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2656
    // sahf
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2657
    emit_opcode( cbuf, 0x9E);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2658
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2659
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2660
  enc_class cmpF_P6_fixup() %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2661
    // Fixup the integer flags in case comparison involved a NaN
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2662
    //
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2663
    // JNP exit (no unordered comparison, P-flag is set by NaN)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2664
    emit_opcode( cbuf, 0x7B );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2665
    emit_d8    ( cbuf, 0x03 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2666
    // MOV AH,1 - treat as LT case (set carry flag)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2667
    emit_opcode( cbuf, 0xB4 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2668
    emit_d8    ( cbuf, 0x01 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2669
    // SAHF
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2670
    emit_opcode( cbuf, 0x9E);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2671
    // NOP     // target for branch to avoid branch to branch
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2672
    emit_opcode( cbuf, 0x90);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2673
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2674
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2675
//     fnstsw_ax();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2676
//     sahf();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2677
//     movl(dst, nan_result);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2678
//     jcc(Assembler::parity, exit);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2679
//     movl(dst, less_result);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2680
//     jcc(Assembler::below, exit);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2681
//     movl(dst, equal_result);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2682
//     jcc(Assembler::equal, exit);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2683
//     movl(dst, greater_result);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2684
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2685
// less_result     =  1;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2686
// greater_result  = -1;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2687
// equal_result    = 0;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2688
// nan_result      = -1;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2689
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  2690
  enc_class CmpF_Result(rRegI dst) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2691
    // fnstsw_ax();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2692
    emit_opcode( cbuf, 0xDF);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2693
    emit_opcode( cbuf, 0xE0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2694
    // sahf
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2695
    emit_opcode( cbuf, 0x9E);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2696
    // movl(dst, nan_result);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2697
    emit_opcode( cbuf, 0xB8 + $dst$$reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2698
    emit_d32( cbuf, -1 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2699
    // jcc(Assembler::parity, exit);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2700
    emit_opcode( cbuf, 0x7A );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2701
    emit_d8    ( cbuf, 0x13 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2702
    // movl(dst, less_result);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2703
    emit_opcode( cbuf, 0xB8 + $dst$$reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2704
    emit_d32( cbuf, -1 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2705
    // jcc(Assembler::below, exit);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2706
    emit_opcode( cbuf, 0x72 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2707
    emit_d8    ( cbuf, 0x0C );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2708
    // movl(dst, equal_result);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2709
    emit_opcode( cbuf, 0xB8 + $dst$$reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2710
    emit_d32( cbuf, 0 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2711
    // jcc(Assembler::equal, exit);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2712
    emit_opcode( cbuf, 0x74 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2713
    emit_d8    ( cbuf, 0x05 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2714
    // movl(dst, greater_result);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2715
    emit_opcode( cbuf, 0xB8 + $dst$$reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2716
    emit_d32( cbuf, 1 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2717
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2718
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2719
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2720
  // Compare the longs and set flags
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2721
  // BROKEN!  Do Not use as-is
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2722
  enc_class cmpl_test( eRegL src1, eRegL src2 ) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2723
    // CMP    $src1.hi,$src2.hi
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2724
    emit_opcode( cbuf, 0x3B );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2725
    emit_rm(cbuf, 0x3, HIGH_FROM_LOW($src1$$reg), HIGH_FROM_LOW($src2$$reg) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2726
    // JNE,s  done
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2727
    emit_opcode(cbuf,0x75);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2728
    emit_d8(cbuf, 2 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2729
    // CMP    $src1.lo,$src2.lo
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2730
    emit_opcode( cbuf, 0x3B );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2731
    emit_rm(cbuf, 0x3, $src1$$reg, $src2$$reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2732
// done:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2733
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2734
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  2735
  enc_class convert_int_long( regL dst, rRegI src ) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2736
    // mov $dst.lo,$src
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2737
    int dst_encoding = $dst$$reg;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2738
    int src_encoding = $src$$reg;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2739
    encode_Copy( cbuf, dst_encoding  , src_encoding );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2740
    // mov $dst.hi,$src
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2741
    encode_Copy( cbuf, HIGH_FROM_LOW(dst_encoding), src_encoding );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2742
    // sar $dst.hi,31
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2743
    emit_opcode( cbuf, 0xC1 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2744
    emit_rm(cbuf, 0x3, 7, HIGH_FROM_LOW(dst_encoding) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2745
    emit_d8(cbuf, 0x1F );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2746
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2747
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2748
  enc_class convert_long_double( eRegL src ) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2749
    // push $src.hi
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2750
    emit_opcode(cbuf, 0x50+HIGH_FROM_LOW($src$$reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2751
    // push $src.lo
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2752
    emit_opcode(cbuf, 0x50+$src$$reg  );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2753
    // fild 64-bits at [SP]
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2754
    emit_opcode(cbuf,0xdf);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2755
    emit_d8(cbuf, 0x6C);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2756
    emit_d8(cbuf, 0x24);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2757
    emit_d8(cbuf, 0x00);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2758
    // pop stack
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2759
    emit_opcode(cbuf, 0x83); // add  SP, #8
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2760
    emit_rm(cbuf, 0x3, 0x00, ESP_enc);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2761
    emit_d8(cbuf, 0x8);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2762
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2763
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2764
  enc_class multiply_con_and_shift_high( eDXRegI dst, nadxRegI src1, eADXRegL_low_only src2, immI_32_63 cnt, eFlagsReg cr ) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2765
    // IMUL   EDX:EAX,$src1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2766
    emit_opcode( cbuf, 0xF7 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2767
    emit_rm( cbuf, 0x3, 0x5, $src1$$reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2768
    // SAR    EDX,$cnt-32
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2769
    int shift_count = ((int)$cnt$$constant) - 32;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2770
    if (shift_count > 0) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2771
      emit_opcode(cbuf, 0xC1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2772
      emit_rm(cbuf, 0x3, 7, $dst$$reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2773
      emit_d8(cbuf, shift_count);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2774
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2775
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2776
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2777
  // this version doesn't have add sp, 8
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2778
  enc_class convert_long_double2( eRegL src ) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2779
    // push $src.hi
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2780
    emit_opcode(cbuf, 0x50+HIGH_FROM_LOW($src$$reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2781
    // push $src.lo
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2782
    emit_opcode(cbuf, 0x50+$src$$reg  );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2783
    // fild 64-bits at [SP]
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2784
    emit_opcode(cbuf,0xdf);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2785
    emit_d8(cbuf, 0x6C);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2786
    emit_d8(cbuf, 0x24);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2787
    emit_d8(cbuf, 0x00);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2788
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2789
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2790
  enc_class long_int_multiply( eADXRegL dst, nadxRegI src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2791
    // Basic idea: long = (long)int * (long)int
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2792
    // IMUL EDX:EAX, src
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2793
    emit_opcode( cbuf, 0xF7 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2794
    emit_rm( cbuf, 0x3, 0x5, $src$$reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2795
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2796
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2797
  enc_class long_uint_multiply( eADXRegL dst, nadxRegI src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2798
    // Basic Idea:  long = (int & 0xffffffffL) * (int & 0xffffffffL)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2799
    // MUL EDX:EAX, src
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2800
    emit_opcode( cbuf, 0xF7 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2801
    emit_rm( cbuf, 0x3, 0x4, $src$$reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2802
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2803
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  2804
  enc_class long_multiply( eADXRegL dst, eRegL src, rRegI tmp ) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2805
    // Basic idea: lo(result) = lo(x_lo * y_lo)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2806
    //             hi(result) = hi(x_lo * y_lo) + lo(x_hi * y_lo) + lo(x_lo * y_hi)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2807
    // MOV    $tmp,$src.lo
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2808
    encode_Copy( cbuf, $tmp$$reg, $src$$reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2809
    // IMUL   $tmp,EDX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2810
    emit_opcode( cbuf, 0x0F );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2811
    emit_opcode( cbuf, 0xAF );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2812
    emit_rm( cbuf, 0x3, $tmp$$reg, HIGH_FROM_LOW($dst$$reg) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2813
    // MOV    EDX,$src.hi
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2814
    encode_Copy( cbuf, HIGH_FROM_LOW($dst$$reg), HIGH_FROM_LOW($src$$reg) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2815
    // IMUL   EDX,EAX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2816
    emit_opcode( cbuf, 0x0F );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2817
    emit_opcode( cbuf, 0xAF );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2818
    emit_rm( cbuf, 0x3, HIGH_FROM_LOW($dst$$reg), $dst$$reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2819
    // ADD    $tmp,EDX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2820
    emit_opcode( cbuf, 0x03 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2821
    emit_rm( cbuf, 0x3, $tmp$$reg, HIGH_FROM_LOW($dst$$reg) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2822
    // MUL   EDX:EAX,$src.lo
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2823
    emit_opcode( cbuf, 0xF7 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2824
    emit_rm( cbuf, 0x3, 0x4, $src$$reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2825
    // ADD    EDX,ESI
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2826
    emit_opcode( cbuf, 0x03 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2827
    emit_rm( cbuf, 0x3, HIGH_FROM_LOW($dst$$reg), $tmp$$reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2828
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2829
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  2830
  enc_class long_multiply_con( eADXRegL dst, immL_127 src, rRegI tmp ) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2831
    // Basic idea: lo(result) = lo(src * y_lo)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2832
    //             hi(result) = hi(src * y_lo) + lo(src * y_hi)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2833
    // IMUL   $tmp,EDX,$src
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2834
    emit_opcode( cbuf, 0x6B );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2835
    emit_rm( cbuf, 0x3, $tmp$$reg, HIGH_FROM_LOW($dst$$reg) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2836
    emit_d8( cbuf, (int)$src$$constant );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2837
    // MOV    EDX,$src
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2838
    emit_opcode(cbuf, 0xB8 + EDX_enc);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2839
    emit_d32( cbuf, (int)$src$$constant );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2840
    // MUL   EDX:EAX,EDX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2841
    emit_opcode( cbuf, 0xF7 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2842
    emit_rm( cbuf, 0x3, 0x4, EDX_enc );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2843
    // ADD    EDX,ESI
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2844
    emit_opcode( cbuf, 0x03 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2845
    emit_rm( cbuf, 0x3, EDX_enc, $tmp$$reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2846
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2847
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2848
  enc_class long_div( eRegL src1, eRegL src2 ) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2849
    // PUSH src1.hi
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2850
    emit_opcode(cbuf, HIGH_FROM_LOW(0x50+$src1$$reg) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2851
    // PUSH src1.lo
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2852
    emit_opcode(cbuf,               0x50+$src1$$reg  );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2853
    // PUSH src2.hi
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2854
    emit_opcode(cbuf, HIGH_FROM_LOW(0x50+$src2$$reg) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2855
    // PUSH src2.lo
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2856
    emit_opcode(cbuf,               0x50+$src2$$reg  );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2857
    // CALL directly to the runtime
6418
6671edbd230e 6978355: renaming for 6961697
twisti
parents: 6272
diff changeset
  2858
    cbuf.set_insts_mark();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2859
    emit_opcode(cbuf,0xE8);       // Call into runtime
6418
6671edbd230e 6978355: renaming for 6961697
twisti
parents: 6272
diff changeset
  2860
    emit_d32_reloc(cbuf, (CAST_FROM_FN_PTR(address, SharedRuntime::ldiv) - cbuf.insts_end()) - 4, runtime_call_Relocation::spec(), RELOC_IMM32 );
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2861
    // Restore stack
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2862
    emit_opcode(cbuf, 0x83); // add  SP, #framesize
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2863
    emit_rm(cbuf, 0x3, 0x00, ESP_enc);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2864
    emit_d8(cbuf, 4*4);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2865
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2866
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2867
  enc_class long_mod( eRegL src1, eRegL src2 ) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2868
    // PUSH src1.hi
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2869
    emit_opcode(cbuf, HIGH_FROM_LOW(0x50+$src1$$reg) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2870
    // PUSH src1.lo
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2871
    emit_opcode(cbuf,               0x50+$src1$$reg  );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2872
    // PUSH src2.hi
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2873
    emit_opcode(cbuf, HIGH_FROM_LOW(0x50+$src2$$reg) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2874
    // PUSH src2.lo
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2875
    emit_opcode(cbuf,               0x50+$src2$$reg  );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2876
    // CALL directly to the runtime
6418
6671edbd230e 6978355: renaming for 6961697
twisti
parents: 6272
diff changeset
  2877
    cbuf.set_insts_mark();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2878
    emit_opcode(cbuf,0xE8);       // Call into runtime
6418
6671edbd230e 6978355: renaming for 6961697
twisti
parents: 6272
diff changeset
  2879
    emit_d32_reloc(cbuf, (CAST_FROM_FN_PTR(address, SharedRuntime::lrem ) - cbuf.insts_end()) - 4, runtime_call_Relocation::spec(), RELOC_IMM32 );
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2880
    // Restore stack
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2881
    emit_opcode(cbuf, 0x83); // add  SP, #framesize
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2882
    emit_rm(cbuf, 0x3, 0x00, ESP_enc);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2883
    emit_d8(cbuf, 4*4);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2884
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2885
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  2886
  enc_class long_cmp_flags0( eRegL src, rRegI tmp ) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2887
    // MOV   $tmp,$src.lo
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2888
    emit_opcode(cbuf, 0x8B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2889
    emit_rm(cbuf, 0x3, $tmp$$reg, $src$$reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2890
    // OR    $tmp,$src.hi
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2891
    emit_opcode(cbuf, 0x0B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2892
    emit_rm(cbuf, 0x3, $tmp$$reg, HIGH_FROM_LOW($src$$reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2893
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2894
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2895
  enc_class long_cmp_flags1( eRegL src1, eRegL src2 ) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2896
    // CMP    $src1.lo,$src2.lo
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2897
    emit_opcode( cbuf, 0x3B );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2898
    emit_rm(cbuf, 0x3, $src1$$reg, $src2$$reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2899
    // JNE,s  skip
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2900
    emit_cc(cbuf, 0x70, 0x5);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2901
    emit_d8(cbuf,2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2902
    // CMP    $src1.hi,$src2.hi
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2903
    emit_opcode( cbuf, 0x3B );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2904
    emit_rm(cbuf, 0x3, HIGH_FROM_LOW($src1$$reg), HIGH_FROM_LOW($src2$$reg) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2905
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2906
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  2907
  enc_class long_cmp_flags2( eRegL src1, eRegL src2, rRegI tmp ) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2908
    // CMP    $src1.lo,$src2.lo\t! Long compare; set flags for low bits
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2909
    emit_opcode( cbuf, 0x3B );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2910
    emit_rm(cbuf, 0x3, $src1$$reg, $src2$$reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2911
    // MOV    $tmp,$src1.hi
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2912
    emit_opcode( cbuf, 0x8B );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2913
    emit_rm(cbuf, 0x3, $tmp$$reg, HIGH_FROM_LOW($src1$$reg) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2914
    // SBB   $tmp,$src2.hi\t! Compute flags for long compare
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2915
    emit_opcode( cbuf, 0x1B );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2916
    emit_rm(cbuf, 0x3, $tmp$$reg, HIGH_FROM_LOW($src2$$reg) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2917
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2918
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  2919
  enc_class long_cmp_flags3( eRegL src, rRegI tmp ) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2920
    // XOR    $tmp,$tmp
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2921
    emit_opcode(cbuf,0x33);  // XOR
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2922
    emit_rm(cbuf,0x3, $tmp$$reg, $tmp$$reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2923
    // CMP    $tmp,$src.lo
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2924
    emit_opcode( cbuf, 0x3B );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2925
    emit_rm(cbuf, 0x3, $tmp$$reg, $src$$reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2926
    // SBB    $tmp,$src.hi
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2927
    emit_opcode( cbuf, 0x1B );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2928
    emit_rm(cbuf, 0x3, $tmp$$reg, HIGH_FROM_LOW($src$$reg) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2929
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2930
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2931
 // Sniff, sniff... smells like Gnu Superoptimizer
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2932
  enc_class neg_long( eRegL dst ) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2933
    emit_opcode(cbuf,0xF7);    // NEG hi
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2934
    emit_rm    (cbuf,0x3, 0x3, HIGH_FROM_LOW($dst$$reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2935
    emit_opcode(cbuf,0xF7);    // NEG lo
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2936
    emit_rm    (cbuf,0x3, 0x3,               $dst$$reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2937
    emit_opcode(cbuf,0x83);    // SBB hi,0
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2938
    emit_rm    (cbuf,0x3, 0x3, HIGH_FROM_LOW($dst$$reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2939
    emit_d8    (cbuf,0 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2940
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2941
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2942
  enc_class enc_pop_rdx() %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2943
    emit_opcode(cbuf,0x5A);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2944
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2945
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2946
  enc_class enc_rethrow() %{
6418
6671edbd230e 6978355: renaming for 6961697
twisti
parents: 6272
diff changeset
  2947
    cbuf.set_insts_mark();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2948
    emit_opcode(cbuf, 0xE9);        // jmp    entry
6418
6671edbd230e 6978355: renaming for 6961697
twisti
parents: 6272
diff changeset
  2949
    emit_d32_reloc(cbuf, (int)OptoRuntime::rethrow_stub() - ((int)cbuf.insts_end())-4,
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2950
                   runtime_call_Relocation::spec(), RELOC_IMM32 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2951
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2952
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2953
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2954
  // Convert a double to an int.  Java semantics require we do complex
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2955
  // manglelations in the corner cases.  So we set the rounding mode to
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2956
  // 'zero', store the darned double down as an int, and reset the
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2957
  // rounding mode to 'nearest'.  The hardware throws an exception which
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2958
  // patches up the correct value directly to the stack.
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  2959
  enc_class DPR2I_encoding( regDPR src ) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2960
    // Flip to round-to-zero mode.  We attempted to allow invalid-op
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2961
    // exceptions here, so that a NAN or other corner-case value will
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2962
    // thrown an exception (but normal values get converted at full speed).
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2963
    // However, I2C adapters and other float-stack manglers leave pending
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2964
    // invalid-op exceptions hanging.  We would have to clear them before
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2965
    // enabling them and that is more expensive than just testing for the
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2966
    // invalid value Intel stores down in the corner cases.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2967
    emit_opcode(cbuf,0xD9);            // FLDCW  trunc
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2968
    emit_opcode(cbuf,0x2D);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2969
    emit_d32(cbuf,(int)StubRoutines::addr_fpu_cntrl_wrd_trunc());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2970
    // Allocate a word
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2971
    emit_opcode(cbuf,0x83);            // SUB ESP,4
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2972
    emit_opcode(cbuf,0xEC);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2973
    emit_d8(cbuf,0x04);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2974
    // Encoding assumes a double has been pushed into FPR0.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2975
    // Store down the double as an int, popping the FPU stack
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2976
    emit_opcode(cbuf,0xDB);            // FISTP [ESP]
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2977
    emit_opcode(cbuf,0x1C);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2978
    emit_d8(cbuf,0x24);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2979
    // Restore the rounding mode; mask the exception
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2980
    emit_opcode(cbuf,0xD9);            // FLDCW   std/24-bit mode
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2981
    emit_opcode(cbuf,0x2D);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2982
    emit_d32( cbuf, Compile::current()->in_24_bit_fp_mode()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2983
        ? (int)StubRoutines::addr_fpu_cntrl_wrd_24()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2984
        : (int)StubRoutines::addr_fpu_cntrl_wrd_std());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2985
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2986
    // Load the converted int; adjust CPU stack
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2987
    emit_opcode(cbuf,0x58);       // POP EAX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2988
    emit_opcode(cbuf,0x3D);       // CMP EAX,imm
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2989
    emit_d32   (cbuf,0x80000000); //         0x80000000
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2990
    emit_opcode(cbuf,0x75);       // JNE around_slow_call
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2991
    emit_d8    (cbuf,0x07);       // Size of slow_call
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2992
    // Push src onto stack slow-path
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2993
    emit_opcode(cbuf,0xD9 );      // FLD     ST(i)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2994
    emit_d8    (cbuf,0xC0-1+$src$$reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2995
    // CALL directly to the runtime
6418
6671edbd230e 6978355: renaming for 6961697
twisti
parents: 6272
diff changeset
  2996
    cbuf.set_insts_mark();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2997
    emit_opcode(cbuf,0xE8);       // Call into runtime
6418
6671edbd230e 6978355: renaming for 6961697
twisti
parents: 6272
diff changeset
  2998
    emit_d32_reloc(cbuf, (StubRoutines::d2i_wrapper() - cbuf.insts_end()) - 4, runtime_call_Relocation::spec(), RELOC_IMM32 );
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2999
    // Carry on here...
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3000
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3001
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  3002
  enc_class DPR2L_encoding( regDPR src ) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3003
    emit_opcode(cbuf,0xD9);            // FLDCW  trunc
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3004
    emit_opcode(cbuf,0x2D);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3005
    emit_d32(cbuf,(int)StubRoutines::addr_fpu_cntrl_wrd_trunc());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3006
    // Allocate a word
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3007
    emit_opcode(cbuf,0x83);            // SUB ESP,8
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3008
    emit_opcode(cbuf,0xEC);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3009
    emit_d8(cbuf,0x08);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3010
    // Encoding assumes a double has been pushed into FPR0.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3011
    // Store down the double as a long, popping the FPU stack
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3012
    emit_opcode(cbuf,0xDF);            // FISTP [ESP]
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3013
    emit_opcode(cbuf,0x3C);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3014
    emit_d8(cbuf,0x24);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3015
    // Restore the rounding mode; mask the exception
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3016
    emit_opcode(cbuf,0xD9);            // FLDCW   std/24-bit mode
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3017
    emit_opcode(cbuf,0x2D);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3018
    emit_d32( cbuf, Compile::current()->in_24_bit_fp_mode()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3019
        ? (int)StubRoutines::addr_fpu_cntrl_wrd_24()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3020
        : (int)StubRoutines::addr_fpu_cntrl_wrd_std());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3021
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3022
    // Load the converted int; adjust CPU stack
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3023
    emit_opcode(cbuf,0x58);       // POP EAX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3024
    emit_opcode(cbuf,0x5A);       // POP EDX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3025
    emit_opcode(cbuf,0x81);       // CMP EDX,imm
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3026
    emit_d8    (cbuf,0xFA);       // rdx
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3027
    emit_d32   (cbuf,0x80000000); //         0x80000000
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3028
    emit_opcode(cbuf,0x75);       // JNE around_slow_call
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3029
    emit_d8    (cbuf,0x07+4);     // Size of slow_call
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3030
    emit_opcode(cbuf,0x85);       // TEST EAX,EAX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3031
    emit_opcode(cbuf,0xC0);       // 2/rax,/rax,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3032
    emit_opcode(cbuf,0x75);       // JNE around_slow_call
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3033
    emit_d8    (cbuf,0x07);       // Size of slow_call
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3034
    // Push src onto stack slow-path
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3035
    emit_opcode(cbuf,0xD9 );      // FLD     ST(i)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3036
    emit_d8    (cbuf,0xC0-1+$src$$reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3037
    // CALL directly to the runtime
6418
6671edbd230e 6978355: renaming for 6961697
twisti
parents: 6272
diff changeset
  3038
    cbuf.set_insts_mark();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3039
    emit_opcode(cbuf,0xE8);       // Call into runtime
6418
6671edbd230e 6978355: renaming for 6961697
twisti
parents: 6272
diff changeset
  3040
    emit_d32_reloc(cbuf, (StubRoutines::d2l_wrapper() - cbuf.insts_end()) - 4, runtime_call_Relocation::spec(), RELOC_IMM32 );
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3041
    // Carry on here...
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3042
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3043
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  3044
  enc_class FMul_ST_reg( eRegFPR src1 ) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3045
    // Operand was loaded from memory into fp ST (stack top)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3046
    // FMUL   ST,$src  /* D8 C8+i */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3047
    emit_opcode(cbuf, 0xD8);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3048
    emit_opcode(cbuf, 0xC8 + $src1$$reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3049
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3050
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  3051
  enc_class FAdd_ST_reg( eRegFPR src2 ) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3052
    // FADDP  ST,src2  /* D8 C0+i */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3053
    emit_opcode(cbuf, 0xD8);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3054
    emit_opcode(cbuf, 0xC0 + $src2$$reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3055
    //could use FADDP  src2,fpST  /* DE C0+i */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3056
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3057
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  3058
  enc_class FAddP_reg_ST( eRegFPR src2 ) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3059
    // FADDP  src2,ST  /* DE C0+i */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3060
    emit_opcode(cbuf, 0xDE);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3061
    emit_opcode(cbuf, 0xC0 + $src2$$reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3062
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3063
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  3064
  enc_class subFPR_divFPR_encode( eRegFPR src1, eRegFPR src2) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3065
    // Operand has been loaded into fp ST (stack top)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3066
      // FSUB   ST,$src1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3067
      emit_opcode(cbuf, 0xD8);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3068
      emit_opcode(cbuf, 0xE0 + $src1$$reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3069
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3070
      // FDIV
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3071
      emit_opcode(cbuf, 0xD8);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3072
      emit_opcode(cbuf, 0xF0 + $src2$$reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3073
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3074
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  3075
  enc_class MulFAddF (eRegFPR src1, eRegFPR src2) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3076
    // Operand was loaded from memory into fp ST (stack top)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3077
    // FADD   ST,$src  /* D8 C0+i */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3078
    emit_opcode(cbuf, 0xD8);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3079
    emit_opcode(cbuf, 0xC0 + $src1$$reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3080
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3081
    // FMUL  ST,src2  /* D8 C*+i */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3082
    emit_opcode(cbuf, 0xD8);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3083
    emit_opcode(cbuf, 0xC8 + $src2$$reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3084
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3085
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3086
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  3087
  enc_class MulFAddFreverse (eRegFPR src1, eRegFPR src2) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3088
    // Operand was loaded from memory into fp ST (stack top)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3089
    // FADD   ST,$src  /* D8 C0+i */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3090
    emit_opcode(cbuf, 0xD8);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3091
    emit_opcode(cbuf, 0xC0 + $src1$$reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3092
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3093
    // FMULP  src2,ST  /* DE C8+i */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3094
    emit_opcode(cbuf, 0xDE);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3095
    emit_opcode(cbuf, 0xC8 + $src2$$reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3096
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3097
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3098
  // Atomically load the volatile long
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3099
  enc_class enc_loadL_volatile( memory mem, stackSlotL dst ) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3100
    emit_opcode(cbuf,0xDF);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3101
    int rm_byte_opcode = 0x05;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3102
    int base     = $mem$$base;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3103
    int index    = $mem$$index;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3104
    int scale    = $mem$$scale;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3105
    int displace = $mem$$disp;
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13485
diff changeset
  3106
    relocInfo::relocType disp_reloc = $mem->disp_reloc(); // disp-as-oop when working with static globals
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13485
diff changeset
  3107
    encode_RegMem(cbuf, rm_byte_opcode, base, index, scale, displace, disp_reloc);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3108
    store_to_stackslot( cbuf, 0x0DF, 0x07, $dst$$disp );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3109
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3110
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3111
  // Volatile Store Long.  Must be atomic, so move it into
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3112
  // the FP TOS and then do a 64-bit FIST.  Has to probe the
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3113
  // target address before the store (for null-ptr checks)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3114
  // so the memory operand is used twice in the encoding.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3115
  enc_class enc_storeL_volatile( memory mem, stackSlotL src ) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3116
    store_to_stackslot( cbuf, 0x0DF, 0x05, $src$$disp );
6418
6671edbd230e 6978355: renaming for 6961697
twisti
parents: 6272
diff changeset
  3117
    cbuf.set_insts_mark();            // Mark start of FIST in case $mem has an oop
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3118
    emit_opcode(cbuf,0xDF);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3119
    int rm_byte_opcode = 0x07;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3120
    int base     = $mem$$base;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3121
    int index    = $mem$$index;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3122
    int scale    = $mem$$scale;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3123
    int displace = $mem$$disp;
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13485
diff changeset
  3124
    relocInfo::relocType disp_reloc = $mem->disp_reloc(); // disp-as-oop when working with static globals
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13485
diff changeset
  3125
    encode_RegMem(cbuf, rm_byte_opcode, base, index, scale, displace, disp_reloc);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3126
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3127
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3128
  // Safepoint Poll.  This polls the safepoint page, and causes an
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3129
  // exception if it is not readable. Unfortunately, it kills the condition code
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3130
  // in the process
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3131
  // We current use TESTL [spp],EDI
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3132
  // A better choice might be TESTB [spp + pagesize() - CacheLineSize()],0
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3133
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3134
  enc_class Safepoint_Poll() %{
6418
6671edbd230e 6978355: renaming for 6961697
twisti
parents: 6272
diff changeset
  3135
    cbuf.relocate(cbuf.insts_mark(), relocInfo::poll_type, 0);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3136
    emit_opcode(cbuf,0x85);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3137
    emit_rm (cbuf, 0x0, 0x7, 0x5);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3138
    emit_d32(cbuf, (intptr_t)os::get_polling_page());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3139
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3140
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3141
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3142
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3143
//----------FRAME--------------------------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3144
// Definition of frame structure and management information.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3145
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3146
//  S T A C K   L A Y O U T    Allocators stack-slot number
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3147
//                             |   (to get allocators register number
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3148
//  G  Owned by    |        |  v    add OptoReg::stack0())
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3149
//  r   CALLER     |        |
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3150
//  o     |        +--------+      pad to even-align allocators stack-slot
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3151
//  w     V        |  pad0  |        numbers; owned by CALLER
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3152
//  t   -----------+--------+----> Matcher::_in_arg_limit, unaligned
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3153
//  h     ^        |   in   |  5
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3154
//        |        |  args  |  4   Holes in incoming args owned by SELF
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3155
//  |     |        |        |  3
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3156
//  |     |        +--------+
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3157
//  V     |        | old out|      Empty on Intel, window on Sparc
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3158
//        |    old |preserve|      Must be even aligned.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3159
//        |     SP-+--------+----> Matcher::_old_SP, even aligned
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3160
//        |        |   in   |  3   area for Intel ret address
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3161
//     Owned by    |preserve|      Empty on Sparc.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3162
//       SELF      +--------+
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3163
//        |        |  pad2  |  2   pad to align old SP
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3164
//        |        +--------+  1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3165
//        |        | locks  |  0
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3166
//        |        +--------+----> OptoReg::stack0(), even aligned
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3167
//        |        |  pad1  | 11   pad to align new SP
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3168
//        |        +--------+
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3169
//        |        |        | 10
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3170
//        |        | spills |  9   spills
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3171
//        V        |        |  8   (pad0 slot for callee)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3172
//      -----------+--------+----> Matcher::_out_arg_limit, unaligned
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3173
//        ^        |  out   |  7
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3174
//        |        |  args  |  6   Holes in outgoing args owned by CALLEE
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3175
//     Owned by    +--------+
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3176
//      CALLEE     | new out|  6   Empty on Intel, window on Sparc
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3177
//        |    new |preserve|      Must be even-aligned.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3178
//        |     SP-+--------+----> Matcher::_new_SP, even aligned
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3179
//        |        |        |
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3180
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3181
// Note 1: Only region 8-11 is determined by the allocator.  Region 0-5 is
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3182
//         known from SELF's arguments and the Java calling convention.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3183
//         Region 6-7 is determined per call site.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3184
// Note 2: If the calling convention leaves holes in the incoming argument
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3185
//         area, those holes are owned by SELF.  Holes in the outgoing area
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3186
//         are owned by the CALLEE.  Holes should not be nessecary in the
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3187
//         incoming area, as the Java calling convention is completely under
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3188
//         the control of the AD file.  Doubles can be sorted and packed to
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3189
//         avoid holes.  Holes in the outgoing arguments may be nessecary for
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3190
//         varargs C calling conventions.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3191
// Note 3: Region 0-3 is even aligned, with pad2 as needed.  Region 3-5 is
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3192
//         even aligned with pad0 as needed.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3193
//         Region 6 is even aligned.  Region 6-7 is NOT even aligned;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3194
//         region 6-11 is even aligned; it may be padded out more so that
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3195
//         the region from SP to FP meets the minimum stack alignment.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3196
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3197
frame %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3198
  // What direction does stack grow in (assumed to be same for C & Java)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3199
  stack_direction(TOWARDS_LOW);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3200
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3201
  // These three registers define part of the calling convention
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3202
  // between compiled code and the interpreter.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3203
  inline_cache_reg(EAX);                // Inline Cache Register
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3204
  interpreter_method_oop_reg(EBX);      // Method Oop Register when calling interpreter
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3205
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3206
  // Optional: name the operand used by cisc-spilling to access [stack_pointer + offset]
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3207
  cisc_spilling_operand_name(indOffset32);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3208
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3209
  // Number of stack slots consumed by locking an object
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3210
  sync_stack_slots(1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3211
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3212
  // Compiled code's Frame Pointer
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3213
  frame_pointer(ESP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3214
  // Interpreter stores its frame pointer in a register which is
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3215
  // stored to the stack by I2CAdaptors.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3216
  // I2CAdaptors convert from interpreted java to compiled java.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3217
  interpreter_frame_pointer(EBP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3218
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3219
  // Stack alignment requirement
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3220
  // Alignment size in bytes (128-bit -> 16 bytes)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3221
  stack_alignment(StackAlignmentInBytes);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3222
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3223
  // Number of stack slots between incoming argument block and the start of
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3224
  // a new frame.  The PROLOG must add this many slots to the stack.  The
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3225
  // EPILOG must remove this many slots.  Intel needs one slot for
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3226
  // return address and one for rbp, (must save rbp)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3227
  in_preserve_stack_slots(2+VerifyStackAtCalls);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3228
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3229
  // Number of outgoing stack slots killed above the out_preserve_stack_slots
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3230
  // for calls to C.  Supports the var-args backing area for register parms.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3231
  varargs_C_out_slots_killed(0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3232
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3233
  // The after-PROLOG location of the return address.  Location of
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3234
  // return address specifies a type (REG or STACK) and a number
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3235
  // representing the register number (i.e. - use a register name) or
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3236
  // stack slot.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3237
  // Ret Addr is on stack in slot 0 if no locks or verification or alignment.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3238
  // Otherwise, it is above the locks and verification slot and alignment word
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3239
  return_addr(STACK - 1 +
11794
72249bf6ab83 7145346: VerifyStackAtCalls is broken
kvn
parents: 11791
diff changeset
  3240
              round_to((Compile::current()->in_preserve_stack_slots() +
72249bf6ab83 7145346: VerifyStackAtCalls is broken
kvn
parents: 11791
diff changeset
  3241
                        Compile::current()->fixed_slots()),
72249bf6ab83 7145346: VerifyStackAtCalls is broken
kvn
parents: 11791
diff changeset
  3242
                       stack_alignment_in_slots()));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3243
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3244
  // Body of function which returns an integer array locating
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3245
  // arguments either in registers or in stack slots.  Passed an array
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3246
  // of ideal registers called "sig" and a "length" count.  Stack-slot
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3247
  // offsets are based on outgoing arguments, i.e. a CALLER setting up
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3248
  // arguments for a CALLEE.  Incoming stack arguments are
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3249
  // automatically biased by the preserve_stack_slots field above.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3250
  calling_convention %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3251
    // No difference between ingoing/outgoing just pass false
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3252
    SharedRuntime::java_calling_convention(sig_bt, regs, length, false);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3253
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3254
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3255
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3256
  // Body of function which returns an integer array locating
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3257
  // arguments either in registers or in stack slots.  Passed an array
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3258
  // of ideal registers called "sig" and a "length" count.  Stack-slot
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3259
  // offsets are based on outgoing arguments, i.e. a CALLER setting up
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3260
  // arguments for a CALLEE.  Incoming stack arguments are
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3261
  // automatically biased by the preserve_stack_slots field above.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3262
  c_calling_convention %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3263
    // This is obviously always outgoing
22832
03720a5b7595 8024344: PPC64 (part 112): C argument in register AND stack slot.
goetz
parents: 17095
diff changeset
  3264
    (void) SharedRuntime::c_calling_convention(sig_bt, regs, /*regs2=*/NULL, length);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3265
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3266
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3267
  // Location of C & interpreter return values
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3268
  c_return_value %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3269
    assert( ideal_reg >= Op_RegI && ideal_reg <= Op_RegL, "only return normal values" );
360
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  3270
    static int lo[Op_RegL+1] = { 0, 0, OptoReg::Bad, EAX_num,      EAX_num,      FPR1L_num,    FPR1L_num, EAX_num };
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  3271
    static int hi[Op_RegL+1] = { 0, 0, OptoReg::Bad, OptoReg::Bad, OptoReg::Bad, OptoReg::Bad, FPR1H_num, EDX_num };
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3272
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3273
    // in SSE2+ mode we want to keep the FPU stack clean so pretend
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3274
    // that C functions return float and double results in XMM0.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3275
    if( ideal_reg == Op_RegD && UseSSE>=2 )
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  3276
      return OptoRegPair(XMM0b_num,XMM0_num);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3277
    if( ideal_reg == Op_RegF && UseSSE>=2 )
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  3278
      return OptoRegPair(OptoReg::Bad,XMM0_num);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3279
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3280
    return OptoRegPair(hi[ideal_reg],lo[ideal_reg]);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3281
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3282
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3283
  // Location of return values
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3284
  return_value %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3285
    assert( ideal_reg >= Op_RegI && ideal_reg <= Op_RegL, "only return normal values" );
360
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  3286
    static int lo[Op_RegL+1] = { 0, 0, OptoReg::Bad, EAX_num,      EAX_num,      FPR1L_num,    FPR1L_num, EAX_num };
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  3287
    static int hi[Op_RegL+1] = { 0, 0, OptoReg::Bad, OptoReg::Bad, OptoReg::Bad, OptoReg::Bad, FPR1H_num, EDX_num };
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3288
    if( ideal_reg == Op_RegD && UseSSE>=2 )
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  3289
      return OptoRegPair(XMM0b_num,XMM0_num);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3290
    if( ideal_reg == Op_RegF && UseSSE>=1 )
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  3291
      return OptoRegPair(OptoReg::Bad,XMM0_num);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3292
    return OptoRegPair(hi[ideal_reg],lo[ideal_reg]);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3293
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3294
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3295
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3296
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3297
//----------ATTRIBUTES---------------------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3298
//----------Operand Attributes-------------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3299
op_attrib op_cost(0);        // Required cost attribute
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3300
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3301
//----------Instruction Attributes---------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3302
ins_attrib ins_cost(100);       // Required cost attribute
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3303
ins_attrib ins_size(8);         // Required size attribute (in bits)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3304
ins_attrib ins_short_branch(0); // Required flag: is this instruction a
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3305
                                // non-matching short branch variant of some
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3306
                                                            // long branch?
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3307
ins_attrib ins_alignment(1);    // Required alignment attribute (must be a power of 2)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3308
                                // specifies the alignment that some part of the instruction (not
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3309
                                // necessarily the start) requires.  If > 1, a compute_padding()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3310
                                // function must be provided for the instruction
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3311
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3312
//----------OPERANDS-----------------------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3313
// Operand definitions must precede instruction definitions for correct parsing
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3314
// in the ADLC because operands constitute user defined types which are used in
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3315
// instruction definitions.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3316
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3317
//----------Simple Operands----------------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3318
// Immediate Operands
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3319
// Integer Immediate
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3320
operand immI() %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3321
  match(ConI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3322
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3323
  op_cost(10);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3324
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3325
  interface(CONST_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3326
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3327
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3328
// Constant for test vs zero
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3329
operand immI0() %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3330
  predicate(n->get_int() == 0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3331
  match(ConI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3332
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3333
  op_cost(0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3334
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3335
  interface(CONST_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3336
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3337
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3338
// Constant for increment
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3339
operand immI1() %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3340
  predicate(n->get_int() == 1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3341
  match(ConI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3342
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3343
  op_cost(0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3344
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3345
  interface(CONST_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3346
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3347
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3348
// Constant for decrement
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3349
operand immI_M1() %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3350
  predicate(n->get_int() == -1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3351
  match(ConI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3352
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3353
  op_cost(0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3354
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3355
  interface(CONST_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3356
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3357
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3358
// Valid scale values for addressing modes
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3359
operand immI2() %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3360
  predicate(0 <= n->get_int() && (n->get_int() <= 3));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3361
  match(ConI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3362
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3363
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3364
  interface(CONST_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3365
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3366
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3367
operand immI8() %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3368
  predicate((-128 <= n->get_int()) && (n->get_int() <= 127));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3369
  match(ConI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3370
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3371
  op_cost(5);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3372
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3373
  interface(CONST_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3374
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3375
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3376
operand immI16() %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3377
  predicate((-32768 <= n->get_int()) && (n->get_int() <= 32767));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3378
  match(ConI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3379
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3380
  op_cost(10);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3381
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3382
  interface(CONST_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3383
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3384
22513
dc47bc8ecb75 8031743: C2: loadI2L_immI broken for negative memory values
iveresov
parents: 21105
diff changeset
  3385
// Int Immediate non-negative
dc47bc8ecb75 8031743: C2: loadI2L_immI broken for negative memory values
iveresov
parents: 21105
diff changeset
  3386
operand immU31()
dc47bc8ecb75 8031743: C2: loadI2L_immI broken for negative memory values
iveresov
parents: 21105
diff changeset
  3387
%{
dc47bc8ecb75 8031743: C2: loadI2L_immI broken for negative memory values
iveresov
parents: 21105
diff changeset
  3388
  predicate(n->get_int() >= 0);
dc47bc8ecb75 8031743: C2: loadI2L_immI broken for negative memory values
iveresov
parents: 21105
diff changeset
  3389
  match(ConI);
dc47bc8ecb75 8031743: C2: loadI2L_immI broken for negative memory values
iveresov
parents: 21105
diff changeset
  3390
dc47bc8ecb75 8031743: C2: loadI2L_immI broken for negative memory values
iveresov
parents: 21105
diff changeset
  3391
  op_cost(0);
dc47bc8ecb75 8031743: C2: loadI2L_immI broken for negative memory values
iveresov
parents: 21105
diff changeset
  3392
  format %{ %}
dc47bc8ecb75 8031743: C2: loadI2L_immI broken for negative memory values
iveresov
parents: 21105
diff changeset
  3393
  interface(CONST_INTER);
dc47bc8ecb75 8031743: C2: loadI2L_immI broken for negative memory values
iveresov
parents: 21105
diff changeset
  3394
%}
dc47bc8ecb75 8031743: C2: loadI2L_immI broken for negative memory values
iveresov
parents: 21105
diff changeset
  3395
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3396
// Constant for long shifts
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3397
operand immI_32() %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3398
  predicate( n->get_int() == 32 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3399
  match(ConI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3400
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3401
  op_cost(0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3402
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3403
  interface(CONST_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3404
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3405
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3406
operand immI_1_31() %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3407
  predicate( n->get_int() >= 1 && n->get_int() <= 31 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3408
  match(ConI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3409
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3410
  op_cost(0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3411
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3412
  interface(CONST_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3413
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3414
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3415
operand immI_32_63() %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3416
  predicate( n->get_int() >= 32 && n->get_int() <= 63 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3417
  match(ConI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3418
  op_cost(0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3419
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3420
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3421
  interface(CONST_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3422
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3423
765
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  3424
operand immI_1() %{
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  3425
  predicate( n->get_int() == 1 );
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  3426
  match(ConI);
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  3427
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  3428
  op_cost(0);
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  3429
  format %{ %}
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  3430
  interface(CONST_INTER);
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  3431
%}
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  3432
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  3433
operand immI_2() %{
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  3434
  predicate( n->get_int() == 2 );
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  3435
  match(ConI);
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  3436
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  3437
  op_cost(0);
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  3438
  format %{ %}
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  3439
  interface(CONST_INTER);
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  3440
%}
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  3441
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  3442
operand immI_3() %{
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  3443
  predicate( n->get_int() == 3 );
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  3444
  match(ConI);
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  3445
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  3446
  op_cost(0);
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  3447
  format %{ %}
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  3448
  interface(CONST_INTER);
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  3449
%}
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  3450
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3451
// Pointer Immediate
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3452
operand immP() %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3453
  match(ConP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3454
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3455
  op_cost(10);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3456
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3457
  interface(CONST_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3458
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3459
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3460
// NULL Pointer Immediate
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3461
operand immP0() %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3462
  predicate( n->get_ptr() == 0 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3463
  match(ConP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3464
  op_cost(0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3465
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3466
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3467
  interface(CONST_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3468
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3469
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3470
// Long Immediate
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3471
operand immL() %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3472
  match(ConL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3473
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3474
  op_cost(20);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3475
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3476
  interface(CONST_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3477
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3478
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3479
// Long Immediate zero
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3480
operand immL0() %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3481
  predicate( n->get_long() == 0L );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3482
  match(ConL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3483
  op_cost(0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3484
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3485
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3486
  interface(CONST_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3487
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3488
1435
72a8da703ff0 6752257: Use NOT instead of XOR -1 on x86
rasbold
parents: 1066
diff changeset
  3489
// Long Immediate zero
72a8da703ff0 6752257: Use NOT instead of XOR -1 on x86
rasbold
parents: 1066
diff changeset
  3490
operand immL_M1() %{
72a8da703ff0 6752257: Use NOT instead of XOR -1 on x86
rasbold
parents: 1066
diff changeset
  3491
  predicate( n->get_long() == -1L );
72a8da703ff0 6752257: Use NOT instead of XOR -1 on x86
rasbold
parents: 1066
diff changeset
  3492
  match(ConL);
72a8da703ff0 6752257: Use NOT instead of XOR -1 on x86
rasbold
parents: 1066
diff changeset
  3493
  op_cost(0);
72a8da703ff0 6752257: Use NOT instead of XOR -1 on x86
rasbold
parents: 1066
diff changeset
  3494
72a8da703ff0 6752257: Use NOT instead of XOR -1 on x86
rasbold
parents: 1066
diff changeset
  3495
  format %{ %}
72a8da703ff0 6752257: Use NOT instead of XOR -1 on x86
rasbold
parents: 1066
diff changeset
  3496
  interface(CONST_INTER);
72a8da703ff0 6752257: Use NOT instead of XOR -1 on x86
rasbold
parents: 1066
diff changeset
  3497
%}
72a8da703ff0 6752257: Use NOT instead of XOR -1 on x86
rasbold
parents: 1066
diff changeset
  3498
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3499
// Long immediate from 0 to 127.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3500
// Used for a shorter form of long mul by 10.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3501
operand immL_127() %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3502
  predicate((0 <= n->get_long()) && (n->get_long() <= 127));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3503
  match(ConL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3504
  op_cost(0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3505
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3506
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3507
  interface(CONST_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3508
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3509
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3510
// Long Immediate: low 32-bit mask
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3511
operand immL_32bits() %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3512
  predicate(n->get_long() == 0xFFFFFFFFL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3513
  match(ConL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3514
  op_cost(0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3515
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3516
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3517
  interface(CONST_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3518
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3519
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3520
// Long Immediate: low 32-bit mask
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3521
operand immL32() %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3522
  predicate(n->get_long() == (int)(n->get_long()));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3523
  match(ConL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3524
  op_cost(20);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3525
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3526
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3527
  interface(CONST_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3528
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3529
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3530
//Double Immediate zero
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  3531
operand immDPR0() %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3532
  // Do additional (and counter-intuitive) test against NaN to work around VC++
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3533
  // bug that generates code such that NaNs compare equal to 0.0
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3534
  predicate( UseSSE<=1 && n->getd() == 0.0 && !g_isnan(n->getd()) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3535
  match(ConD);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3536
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3537
  op_cost(5);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3538
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3539
  interface(CONST_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3540
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3541
7433
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  3542
// Double Immediate one
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  3543
operand immDPR1() %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3544
  predicate( UseSSE<=1 && n->getd() == 1.0 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3545
  match(ConD);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3546
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3547
  op_cost(5);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3548
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3549
  interface(CONST_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3550
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3551
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3552
// Double Immediate
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  3553
operand immDPR() %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3554
  predicate(UseSSE<=1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3555
  match(ConD);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3556
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3557
  op_cost(5);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3558
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3559
  interface(CONST_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3560
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3561
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  3562
operand immD() %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3563
  predicate(UseSSE>=2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3564
  match(ConD);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3565
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3566
  op_cost(5);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3567
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3568
  interface(CONST_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3569
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3570
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3571
// Double Immediate zero
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  3572
operand immD0() %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3573
  // Do additional (and counter-intuitive) test against NaN to work around VC++
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3574
  // bug that generates code such that NaNs compare equal to 0.0 AND do not
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3575
  // compare equal to -0.0.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3576
  predicate( UseSSE>=2 && jlong_cast(n->getd()) == 0 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3577
  match(ConD);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3578
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3579
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3580
  interface(CONST_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3581
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3582
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3583
// Float Immediate zero
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  3584
operand immFPR0() %{
7433
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  3585
  predicate(UseSSE == 0 && n->getf() == 0.0F);
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  3586
  match(ConF);
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  3587
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  3588
  op_cost(5);
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  3589
  format %{ %}
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  3590
  interface(CONST_INTER);
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  3591
%}
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  3592
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  3593
// Float Immediate one
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  3594
operand immFPR1() %{
7433
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  3595
  predicate(UseSSE == 0 && n->getf() == 1.0F);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3596
  match(ConF);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3597
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3598
  op_cost(5);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3599
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3600
  interface(CONST_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3601
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3602
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3603
// Float Immediate
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  3604
operand immFPR() %{
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  3605
  predicate( UseSSE == 0 );
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  3606
  match(ConF);
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  3607
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  3608
  op_cost(5);
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  3609
  format %{ %}
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  3610
  interface(CONST_INTER);
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  3611
%}
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  3612
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  3613
// Float Immediate
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3614
operand immF() %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3615
  predicate(UseSSE >= 1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3616
  match(ConF);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3617
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3618
  op_cost(5);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3619
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3620
  interface(CONST_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3621
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3622
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3623
// Float Immediate zero.  Zero and not -0.0
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  3624
operand immF0() %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3625
  predicate( UseSSE >= 1 && jint_cast(n->getf()) == 0 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3626
  match(ConF);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3627
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3628
  op_cost(5);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3629
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3630
  interface(CONST_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3631
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3632
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3633
// Immediates for special shifts (sign extend)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3634
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3635
// Constants for increment
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3636
operand immI_16() %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3637
  predicate( n->get_int() == 16 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3638
  match(ConI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3639
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3640
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3641
  interface(CONST_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3642
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3643
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3644
operand immI_24() %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3645
  predicate( n->get_int() == 24 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3646
  match(ConI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3647
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3648
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3649
  interface(CONST_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3650
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3651
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3652
// Constant for byte-wide masking
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3653
operand immI_255() %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3654
  predicate( n->get_int() == 255 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3655
  match(ConI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3656
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3657
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3658
  interface(CONST_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3659
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3660
2872
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  3661
// Constant for short-wide masking
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  3662
operand immI_65535() %{
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  3663
  predicate(n->get_int() == 65535);
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  3664
  match(ConI);
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  3665
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  3666
  format %{ %}
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  3667
  interface(CONST_INTER);
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  3668
%}
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  3669
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3670
// Register Operands
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3671
// Integer Register
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  3672
operand rRegI() %{
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  3673
  constraint(ALLOC_IN_RC(int_reg));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3674
  match(RegI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3675
  match(xRegI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3676
  match(eAXRegI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3677
  match(eBXRegI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3678
  match(eCXRegI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3679
  match(eDXRegI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3680
  match(eDIRegI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3681
  match(eSIRegI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3682
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3683
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3684
  interface(REG_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3685
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3686
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3687
// Subset of Integer Register
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  3688
operand xRegI(rRegI reg) %{
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  3689
  constraint(ALLOC_IN_RC(int_x_reg));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3690
  match(reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3691
  match(eAXRegI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3692
  match(eBXRegI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3693
  match(eCXRegI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3694
  match(eDXRegI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3695
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3696
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3697
  interface(REG_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3698
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3699
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3700
// Special Registers
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3701
operand eAXRegI(xRegI reg) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3702
  constraint(ALLOC_IN_RC(eax_reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3703
  match(reg);
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  3704
  match(rRegI);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3705
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3706
  format %{ "EAX" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3707
  interface(REG_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3708
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3709
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3710
// Special Registers
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3711
operand eBXRegI(xRegI reg) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3712
  constraint(ALLOC_IN_RC(ebx_reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3713
  match(reg);
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  3714
  match(rRegI);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3715
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3716
  format %{ "EBX" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3717
  interface(REG_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3718
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3719
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3720
operand eCXRegI(xRegI reg) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3721
  constraint(ALLOC_IN_RC(ecx_reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3722
  match(reg);
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  3723
  match(rRegI);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3724
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3725
  format %{ "ECX" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3726
  interface(REG_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3727
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3728
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3729
operand eDXRegI(xRegI reg) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3730
  constraint(ALLOC_IN_RC(edx_reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3731
  match(reg);
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  3732
  match(rRegI);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3733
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3734
  format %{ "EDX" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3735
  interface(REG_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3736
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3737
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3738
operand eDIRegI(xRegI reg) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3739
  constraint(ALLOC_IN_RC(edi_reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3740
  match(reg);
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  3741
  match(rRegI);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3742
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3743
  format %{ "EDI" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3744
  interface(REG_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3745
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3746
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3747
operand naxRegI() %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3748
  constraint(ALLOC_IN_RC(nax_reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3749
  match(RegI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3750
  match(eCXRegI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3751
  match(eDXRegI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3752
  match(eSIRegI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3753
  match(eDIRegI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3754
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3755
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3756
  interface(REG_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3757
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3758
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3759
operand nadxRegI() %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3760
  constraint(ALLOC_IN_RC(nadx_reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3761
  match(RegI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3762
  match(eBXRegI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3763
  match(eCXRegI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3764
  match(eSIRegI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3765
  match(eDIRegI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3766
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3767
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3768
  interface(REG_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3769
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3770
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3771
operand ncxRegI() %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3772
  constraint(ALLOC_IN_RC(ncx_reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3773
  match(RegI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3774
  match(eAXRegI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3775
  match(eDXRegI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3776
  match(eSIRegI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3777
  match(eDIRegI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3778
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3779
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3780
  interface(REG_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3781
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3782
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3783
// // This operand was used by cmpFastUnlock, but conflicted with 'object' reg
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3784
// //
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3785
operand eSIRegI(xRegI reg) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3786
   constraint(ALLOC_IN_RC(esi_reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3787
   match(reg);
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  3788
   match(rRegI);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3789
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3790
   format %{ "ESI" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3791
   interface(REG_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3792
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3793
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3794
// Pointer Register
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3795
operand anyRegP() %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3796
  constraint(ALLOC_IN_RC(any_reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3797
  match(RegP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3798
  match(eAXRegP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3799
  match(eBXRegP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3800
  match(eCXRegP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3801
  match(eDIRegP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3802
  match(eRegP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3803
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3804
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3805
  interface(REG_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3806
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3807
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3808
operand eRegP() %{
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  3809
  constraint(ALLOC_IN_RC(int_reg));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3810
  match(RegP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3811
  match(eAXRegP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3812
  match(eBXRegP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3813
  match(eCXRegP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3814
  match(eDIRegP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3815
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3816
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3817
  interface(REG_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3818
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3819
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3820
// On windows95, EBP is not safe to use for implicit null tests.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3821
operand eRegP_no_EBP() %{
30305
b92a97e1e9cb 8068945: Use RBP register as proper frame pointer in JIT compiled code on x86
zmajo
parents: 28954
diff changeset
  3822
  constraint(ALLOC_IN_RC(int_reg_no_ebp));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3823
  match(RegP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3824
  match(eAXRegP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3825
  match(eBXRegP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3826
  match(eCXRegP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3827
  match(eDIRegP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3828
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3829
  op_cost(100);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3830
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3831
  interface(REG_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3832
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3833
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3834
operand naxRegP() %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3835
  constraint(ALLOC_IN_RC(nax_reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3836
  match(RegP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3837
  match(eBXRegP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3838
  match(eDXRegP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3839
  match(eCXRegP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3840
  match(eSIRegP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3841
  match(eDIRegP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3842
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3843
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3844
  interface(REG_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3845
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3846
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3847
operand nabxRegP() %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3848
  constraint(ALLOC_IN_RC(nabx_reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3849
  match(RegP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3850
  match(eCXRegP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3851
  match(eDXRegP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3852
  match(eSIRegP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3853
  match(eDIRegP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3854
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3855
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3856
  interface(REG_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3857
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3858
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3859
operand pRegP() %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3860
  constraint(ALLOC_IN_RC(p_reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3861
  match(RegP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3862
  match(eBXRegP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3863
  match(eDXRegP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3864
  match(eSIRegP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3865
  match(eDIRegP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3866
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3867
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3868
  interface(REG_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3869
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3870
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3871
// Special Registers
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3872
// Return a pointer value
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3873
operand eAXRegP(eRegP reg) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3874
  constraint(ALLOC_IN_RC(eax_reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3875
  match(reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3876
  format %{ "EAX" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3877
  interface(REG_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3878
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3879
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3880
// Used in AtomicAdd
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3881
operand eBXRegP(eRegP reg) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3882
  constraint(ALLOC_IN_RC(ebx_reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3883
  match(reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3884
  format %{ "EBX" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3885
  interface(REG_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3886
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3887
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3888
// Tail-call (interprocedural jump) to interpreter
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3889
operand eCXRegP(eRegP reg) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3890
  constraint(ALLOC_IN_RC(ecx_reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3891
  match(reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3892
  format %{ "ECX" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3893
  interface(REG_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3894
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3895
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3896
operand eSIRegP(eRegP reg) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3897
  constraint(ALLOC_IN_RC(esi_reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3898
  match(reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3899
  format %{ "ESI" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3900
  interface(REG_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3901
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3902
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3903
// Used in rep stosw
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3904
operand eDIRegP(eRegP reg) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3905
  constraint(ALLOC_IN_RC(edi_reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3906
  match(reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3907
  format %{ "EDI" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3908
  interface(REG_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3909
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3910
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3911
operand eRegL() %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3912
  constraint(ALLOC_IN_RC(long_reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3913
  match(RegL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3914
  match(eADXRegL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3915
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3916
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3917
  interface(REG_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3918
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3919
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3920
operand eADXRegL( eRegL reg ) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3921
  constraint(ALLOC_IN_RC(eadx_reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3922
  match(reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3923
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3924
  format %{ "EDX:EAX" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3925
  interface(REG_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3926
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3927
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3928
operand eBCXRegL( eRegL reg ) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3929
  constraint(ALLOC_IN_RC(ebcx_reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3930
  match(reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3931
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3932
  format %{ "EBX:ECX" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3933
  interface(REG_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3934
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3935
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3936
// Special case for integer high multiply
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3937
operand eADXRegL_low_only() %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3938
  constraint(ALLOC_IN_RC(eadx_reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3939
  match(RegL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3940
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3941
  format %{ "EAX" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3942
  interface(REG_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3943
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3944
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3945
// Flags register, used as output of compare instructions
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3946
operand eFlagsReg() %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3947
  constraint(ALLOC_IN_RC(int_flags));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3948
  match(RegFlags);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3949
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3950
  format %{ "EFLAGS" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3951
  interface(REG_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3952
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3953
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3954
// Flags register, used as output of FLOATING POINT compare instructions
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3955
operand eFlagsRegU() %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3956
  constraint(ALLOC_IN_RC(int_flags));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3957
  match(RegFlags);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3958
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3959
  format %{ "EFLAGS_U" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3960
  interface(REG_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3961
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3962
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  3963
operand eFlagsRegUCF() %{
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  3964
  constraint(ALLOC_IN_RC(int_flags));
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  3965
  match(RegFlags);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  3966
  predicate(false);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  3967
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  3968
  format %{ "EFLAGS_U_CF" %}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  3969
  interface(REG_INTER);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  3970
%}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  3971
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3972
// Condition Code Register used by long compare
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3973
operand flagsReg_long_LTGE() %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3974
  constraint(ALLOC_IN_RC(int_flags));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3975
  match(RegFlags);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3976
  format %{ "FLAGS_LTGE" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3977
  interface(REG_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3978
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3979
operand flagsReg_long_EQNE() %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3980
  constraint(ALLOC_IN_RC(int_flags));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3981
  match(RegFlags);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3982
  format %{ "FLAGS_EQNE" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3983
  interface(REG_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3984
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3985
operand flagsReg_long_LEGT() %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3986
  constraint(ALLOC_IN_RC(int_flags));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3987
  match(RegFlags);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3988
  format %{ "FLAGS_LEGT" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3989
  interface(REG_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3990
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3991
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3992
// Float register operands
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  3993
operand regDPR() %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3994
  predicate( UseSSE < 2 );
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  3995
  constraint(ALLOC_IN_RC(fp_dbl_reg));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3996
  match(RegD);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3997
  match(regDPR1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3998
  match(regDPR2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3999
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4000
  interface(REG_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4001
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4002
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  4003
operand regDPR1(regDPR reg) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4004
  predicate( UseSSE < 2 );
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  4005
  constraint(ALLOC_IN_RC(fp_dbl_reg0));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4006
  match(reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4007
  format %{ "FPR1" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4008
  interface(REG_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4009
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4010
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  4011
operand regDPR2(regDPR reg) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4012
  predicate( UseSSE < 2 );
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  4013
  constraint(ALLOC_IN_RC(fp_dbl_reg1));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4014
  match(reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4015
  format %{ "FPR2" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4016
  interface(REG_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4017
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4018
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  4019
operand regnotDPR1(regDPR reg) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4020
  predicate( UseSSE < 2 );
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  4021
  constraint(ALLOC_IN_RC(fp_dbl_notreg0));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4022
  match(reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4023
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4024
  interface(REG_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4025
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4026
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4027
// Float register operands
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  4028
operand regFPR() %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4029
  predicate( UseSSE < 2 );
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  4030
  constraint(ALLOC_IN_RC(fp_flt_reg));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4031
  match(RegF);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4032
  match(regFPR1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4033
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4034
  interface(REG_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4035
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4036
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4037
// Float register operands
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  4038
operand regFPR1(regFPR reg) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4039
  predicate( UseSSE < 2 );
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  4040
  constraint(ALLOC_IN_RC(fp_flt_reg0));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4041
  match(reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4042
  format %{ "FPR1" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4043
  interface(REG_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4044
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4045
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  4046
// XMM Float register operands
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  4047
operand regF() %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4048
  predicate( UseSSE>=1 );
30624
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
  4049
  constraint(ALLOC_IN_RC(float_reg_legacy));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4050
  match(RegF);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4051
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4052
  interface(REG_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4053
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4054
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  4055
// XMM Double register operands
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  4056
operand regD() %{
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  4057
  predicate( UseSSE>=2 );
30624
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
  4058
  constraint(ALLOC_IN_RC(double_reg_legacy));
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  4059
  match(RegD);
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  4060
  format %{ %}
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  4061
  interface(REG_INTER);
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  4062
%}
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  4063
30624
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
  4064
// Vectors : note, we use legacy registers to avoid extra (unneeded in 32-bit VM)
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
  4065
// runtime code generation via reg_class_dynamic.
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
  4066
operand vecS() %{
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
  4067
  constraint(ALLOC_IN_RC(vectors_reg_legacy));
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
  4068
  match(VecS);
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
  4069
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
  4070
  format %{ %}
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
  4071
  interface(REG_INTER);
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
  4072
%}
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
  4073
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
  4074
operand vecD() %{
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
  4075
  constraint(ALLOC_IN_RC(vectord_reg_legacy));
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
  4076
  match(VecD);
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
  4077
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
  4078
  format %{ %}
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
  4079
  interface(REG_INTER);
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
  4080
%}
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
  4081
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
  4082
operand vecX() %{
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
  4083
  constraint(ALLOC_IN_RC(vectorx_reg_legacy));
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
  4084
  match(VecX);
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
  4085
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
  4086
  format %{ %}
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
  4087
  interface(REG_INTER);
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
  4088
%}
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
  4089
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
  4090
operand vecY() %{
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
  4091
  constraint(ALLOC_IN_RC(vectory_reg_legacy));
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
  4092
  match(VecY);
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
  4093
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
  4094
  format %{ %}
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
  4095
  interface(REG_INTER);
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
  4096
%}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4097
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4098
//----------Memory Operands----------------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4099
// Direct Memory Operand
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4100
operand direct(immP addr) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4101
  match(addr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4102
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4103
  format %{ "[$addr]" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4104
  interface(MEMORY_INTER) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4105
    base(0xFFFFFFFF);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4106
    index(0x4);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4107
    scale(0x0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4108
    disp($addr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4109
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4110
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4111
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4112
// Indirect Memory Operand
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4113
operand indirect(eRegP reg) %{
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  4114
  constraint(ALLOC_IN_RC(int_reg));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4115
  match(reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4116
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4117
  format %{ "[$reg]" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4118
  interface(MEMORY_INTER) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4119
    base($reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4120
    index(0x4);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4121
    scale(0x0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4122
    disp(0x0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4123
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4124
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4125
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4126
// Indirect Memory Plus Short Offset Operand
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4127
operand indOffset8(eRegP reg, immI8 off) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4128
  match(AddP reg off);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4129
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4130
  format %{ "[$reg + $off]" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4131
  interface(MEMORY_INTER) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4132
    base($reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4133
    index(0x4);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4134
    scale(0x0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4135
    disp($off);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4136
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4137
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4138
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4139
// Indirect Memory Plus Long Offset Operand
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4140
operand indOffset32(eRegP reg, immI off) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4141
  match(AddP reg off);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4142
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4143
  format %{ "[$reg + $off]" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4144
  interface(MEMORY_INTER) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4145
    base($reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4146
    index(0x4);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4147
    scale(0x0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4148
    disp($off);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4149
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4150
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4151
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4152
// Indirect Memory Plus Long Offset Operand
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  4153
operand indOffset32X(rRegI reg, immP off) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4154
  match(AddP off reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4155
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4156
  format %{ "[$reg + $off]" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4157
  interface(MEMORY_INTER) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4158
    base($reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4159
    index(0x4);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4160
    scale(0x0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4161
    disp($off);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4162
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4163
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4164
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4165
// Indirect Memory Plus Index Register Plus Offset Operand
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  4166
operand indIndexOffset(eRegP reg, rRegI ireg, immI off) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4167
  match(AddP (AddP reg ireg) off);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4168
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4169
  op_cost(10);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4170
  format %{"[$reg + $off + $ireg]" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4171
  interface(MEMORY_INTER) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4172
    base($reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4173
    index($ireg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4174
    scale(0x0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4175
    disp($off);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4176
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4177
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4178
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4179
// Indirect Memory Plus Index Register Plus Offset Operand
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  4180
operand indIndex(eRegP reg, rRegI ireg) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4181
  match(AddP reg ireg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4182
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4183
  op_cost(10);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4184
  format %{"[$reg + $ireg]" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4185
  interface(MEMORY_INTER) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4186
    base($reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4187
    index($ireg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4188
    scale(0x0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4189
    disp(0x0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4190
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4191
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4192
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4193
// // -------------------------------------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4194
// // 486 architecture doesn't support "scale * index + offset" with out a base
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4195
// // -------------------------------------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4196
// // Scaled Memory Operands
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4197
// // Indirect Memory Times Scale Plus Offset Operand
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  4198
// operand indScaleOffset(immP off, rRegI ireg, immI2 scale) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4199
//   match(AddP off (LShiftI ireg scale));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4200
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4201
//   op_cost(10);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4202
//   format %{"[$off + $ireg << $scale]" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4203
//   interface(MEMORY_INTER) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4204
//     base(0x4);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4205
//     index($ireg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4206
//     scale($scale);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4207
//     disp($off);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4208
//   %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4209
// %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4210
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4211
// Indirect Memory Times Scale Plus Index Register
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  4212
operand indIndexScale(eRegP reg, rRegI ireg, immI2 scale) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4213
  match(AddP reg (LShiftI ireg scale));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4214
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4215
  op_cost(10);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4216
  format %{"[$reg + $ireg << $scale]" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4217
  interface(MEMORY_INTER) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4218
    base($reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4219
    index($ireg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4220
    scale($scale);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4221
    disp(0x0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4222
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4223
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4224
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4225
// Indirect Memory Times Scale Plus Index Register Plus Offset Operand
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  4226
operand indIndexScaleOffset(eRegP reg, immI off, rRegI ireg, immI2 scale) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4227
  match(AddP (AddP reg (LShiftI ireg scale)) off);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4228
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4229
  op_cost(10);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4230
  format %{"[$reg + $off + $ireg << $scale]" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4231
  interface(MEMORY_INTER) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4232
    base($reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4233
    index($ireg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4234
    scale($scale);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4235
    disp($off);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4236
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4237
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4238
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4239
//----------Load Long Memory Operands------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4240
// The load-long idiom will use it's address expression again after loading
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4241
// the first word of the long.  If the load-long destination overlaps with
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4242
// registers used in the addressing expression, the 2nd half will be loaded
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4243
// from a clobbered address.  Fix this by requiring that load-long use
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4244
// address registers that do not overlap with the load-long target.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4245
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4246
// load-long support
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4247
operand load_long_RegP() %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4248
  constraint(ALLOC_IN_RC(esi_reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4249
  match(RegP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4250
  match(eSIRegP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4251
  op_cost(100);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4252
  format %{  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4253
  interface(REG_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4254
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4255
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4256
// Indirect Memory Operand Long
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4257
operand load_long_indirect(load_long_RegP reg) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4258
  constraint(ALLOC_IN_RC(esi_reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4259
  match(reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4260
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4261
  format %{ "[$reg]" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4262
  interface(MEMORY_INTER) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4263
    base($reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4264
    index(0x4);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4265
    scale(0x0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4266
    disp(0x0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4267
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4268
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4269
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4270
// Indirect Memory Plus Long Offset Operand
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4271
operand load_long_indOffset32(load_long_RegP reg, immI off) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4272
  match(AddP reg off);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4273
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4274
  format %{ "[$reg + $off]" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4275
  interface(MEMORY_INTER) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4276
    base($reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4277
    index(0x4);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4278
    scale(0x0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4279
    disp($off);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4280
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4281
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4282
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4283
opclass load_long_memory(load_long_indirect, load_long_indOffset32);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4284
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4285
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4286
//----------Special Memory Operands--------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4287
// Stack Slot Operand - This operand is used for loading and storing temporary
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4288
//                      values on the stack where a match requires a value to
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4289
//                      flow through memory.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4290
operand stackSlotP(sRegP reg) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4291
  constraint(ALLOC_IN_RC(stack_slots));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4292
  // No match rule because this operand is only generated in matching
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4293
  format %{ "[$reg]" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4294
  interface(MEMORY_INTER) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4295
    base(0x4);   // ESP
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4296
    index(0x4);  // No Index
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4297
    scale(0x0);  // No Scale
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4298
    disp($reg);  // Stack Offset
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4299
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4300
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4301
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4302
operand stackSlotI(sRegI reg) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4303
  constraint(ALLOC_IN_RC(stack_slots));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4304
  // No match rule because this operand is only generated in matching
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4305
  format %{ "[$reg]" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4306
  interface(MEMORY_INTER) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4307
    base(0x4);   // ESP
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4308
    index(0x4);  // No Index
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4309
    scale(0x0);  // No Scale
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4310
    disp($reg);  // Stack Offset
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4311
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4312
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4313
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4314
operand stackSlotF(sRegF reg) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4315
  constraint(ALLOC_IN_RC(stack_slots));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4316
  // No match rule because this operand is only generated in matching
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4317
  format %{ "[$reg]" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4318
  interface(MEMORY_INTER) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4319
    base(0x4);   // ESP
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4320
    index(0x4);  // No Index
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4321
    scale(0x0);  // No Scale
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4322
    disp($reg);  // Stack Offset
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4323
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4324
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4325
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4326
operand stackSlotD(sRegD reg) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4327
  constraint(ALLOC_IN_RC(stack_slots));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4328
  // No match rule because this operand is only generated in matching
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4329
  format %{ "[$reg]" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4330
  interface(MEMORY_INTER) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4331
    base(0x4);   // ESP
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4332
    index(0x4);  // No Index
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4333
    scale(0x0);  // No Scale
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4334
    disp($reg);  // Stack Offset
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4335
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4336
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4337
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4338
operand stackSlotL(sRegL reg) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4339
  constraint(ALLOC_IN_RC(stack_slots));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4340
  // No match rule because this operand is only generated in matching
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4341
  format %{ "[$reg]" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4342
  interface(MEMORY_INTER) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4343
    base(0x4);   // ESP
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4344
    index(0x4);  // No Index
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4345
    scale(0x0);  // No Scale
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4346
    disp($reg);  // Stack Offset
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4347
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4348
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4349
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4350
//----------Memory Operands - Win95 Implicit Null Variants----------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4351
// Indirect Memory Operand
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4352
operand indirect_win95_safe(eRegP_no_EBP reg)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4353
%{
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  4354
  constraint(ALLOC_IN_RC(int_reg));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4355
  match(reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4356
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4357
  op_cost(100);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4358
  format %{ "[$reg]" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4359
  interface(MEMORY_INTER) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4360
    base($reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4361
    index(0x4);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4362
    scale(0x0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4363
    disp(0x0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4364
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4365
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4366
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4367
// Indirect Memory Plus Short Offset Operand
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4368
operand indOffset8_win95_safe(eRegP_no_EBP reg, immI8 off)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4369
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4370
  match(AddP reg off);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4371
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4372
  op_cost(100);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4373
  format %{ "[$reg + $off]" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4374
  interface(MEMORY_INTER) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4375
    base($reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4376
    index(0x4);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4377
    scale(0x0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4378
    disp($off);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4379
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4380
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4381
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4382
// Indirect Memory Plus Long Offset Operand
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4383
operand indOffset32_win95_safe(eRegP_no_EBP reg, immI off)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4384
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4385
  match(AddP reg off);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4386
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4387
  op_cost(100);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4388
  format %{ "[$reg + $off]" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4389
  interface(MEMORY_INTER) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4390
    base($reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4391
    index(0x4);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4392
    scale(0x0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4393
    disp($off);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4394
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4395
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4396
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4397
// Indirect Memory Plus Index Register Plus Offset Operand
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  4398
operand indIndexOffset_win95_safe(eRegP_no_EBP reg, rRegI ireg, immI off)
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4399
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4400
  match(AddP (AddP reg ireg) off);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4401
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4402
  op_cost(100);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4403
  format %{"[$reg + $off + $ireg]" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4404
  interface(MEMORY_INTER) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4405
    base($reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4406
    index($ireg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4407
    scale(0x0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4408
    disp($off);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4409
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4410
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4411
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4412
// Indirect Memory Times Scale Plus Index Register
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  4413
operand indIndexScale_win95_safe(eRegP_no_EBP reg, rRegI ireg, immI2 scale)
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4414
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4415
  match(AddP reg (LShiftI ireg scale));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4416
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4417
  op_cost(100);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4418
  format %{"[$reg + $ireg << $scale]" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4419
  interface(MEMORY_INTER) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4420
    base($reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4421
    index($ireg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4422
    scale($scale);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4423
    disp(0x0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4424
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4425
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4426
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4427
// Indirect Memory Times Scale Plus Index Register Plus Offset Operand
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  4428
operand indIndexScaleOffset_win95_safe(eRegP_no_EBP reg, immI off, rRegI ireg, immI2 scale)
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4429
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4430
  match(AddP (AddP reg (LShiftI ireg scale)) off);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4431
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4432
  op_cost(100);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4433
  format %{"[$reg + $off + $ireg << $scale]" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4434
  interface(MEMORY_INTER) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4435
    base($reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4436
    index($ireg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4437
    scale($scale);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4438
    disp($off);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4439
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4440
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4441
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4442
//----------Conditional Branch Operands----------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4443
// Comparison Op  - This is the operation of the comparison, and is limited to
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4444
//                  the following set of codes:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4445
//                  L (<), LE (<=), G (>), GE (>=), E (==), NE (!=)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4446
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4447
// Other attributes of the comparison, such as unsignedness, are specified
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4448
// by the comparison instruction that sets a condition code flags register.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4449
// That result is represented by a flags operand whose subtype is appropriate
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4450
// to the unsignedness (etc.) of the comparison.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4451
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4452
// Later, the instruction which matches both the Comparison Op (a Bool) and
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4453
// the flags (produced by the Cmp) specifies the coding of the comparison op
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4454
// by matching a specific subtype of Bool operand below, such as cmpOpU.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4455
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4456
// Comparision Code
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4457
operand cmpOp() %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4458
  match(Bool);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4459
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4460
  format %{ "" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4461
  interface(COND_INTER) %{
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  4462
    equal(0x4, "e");
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  4463
    not_equal(0x5, "ne");
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  4464
    less(0xC, "l");
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  4465
    greater_equal(0xD, "ge");
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  4466
    less_equal(0xE, "le");
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  4467
    greater(0xF, "g");
20289
35d78de0c547 8024924: Intrinsify java.lang.Math.addExact
rbackman
parents: 17095
diff changeset
  4468
    overflow(0x0, "o");
35d78de0c547 8024924: Intrinsify java.lang.Math.addExact
rbackman
parents: 17095
diff changeset
  4469
    no_overflow(0x1, "no");
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4470
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4471
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4472
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4473
// Comparison Code, unsigned compare.  Used by FP also, with
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4474
// C2 (unordered) turned into GT or LT already.  The other bits
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4475
// C0 and C3 are turned into Carry & Zero flags.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4476
operand cmpOpU() %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4477
  match(Bool);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4478
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4479
  format %{ "" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4480
  interface(COND_INTER) %{
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  4481
    equal(0x4, "e");
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  4482
    not_equal(0x5, "ne");
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  4483
    less(0x2, "b");
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  4484
    greater_equal(0x3, "nb");
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  4485
    less_equal(0x6, "be");
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  4486
    greater(0x7, "nbe");
20289
35d78de0c547 8024924: Intrinsify java.lang.Math.addExact
rbackman
parents: 17095
diff changeset
  4487
    overflow(0x0, "o");
35d78de0c547 8024924: Intrinsify java.lang.Math.addExact
rbackman
parents: 17095
diff changeset
  4488
    no_overflow(0x1, "no");
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  4489
  %}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  4490
%}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  4491
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  4492
// Floating comparisons that don't require any fixup for the unordered case
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  4493
operand cmpOpUCF() %{
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  4494
  match(Bool);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  4495
  predicate(n->as_Bool()->_test._test == BoolTest::lt ||
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  4496
            n->as_Bool()->_test._test == BoolTest::ge ||
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  4497
            n->as_Bool()->_test._test == BoolTest::le ||
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  4498
            n->as_Bool()->_test._test == BoolTest::gt);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  4499
  format %{ "" %}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  4500
  interface(COND_INTER) %{
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  4501
    equal(0x4, "e");
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  4502
    not_equal(0x5, "ne");
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  4503
    less(0x2, "b");
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  4504
    greater_equal(0x3, "nb");
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  4505
    less_equal(0x6, "be");
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  4506
    greater(0x7, "nbe");
20289
35d78de0c547 8024924: Intrinsify java.lang.Math.addExact
rbackman
parents: 17095
diff changeset
  4507
    overflow(0x0, "o");
35d78de0c547 8024924: Intrinsify java.lang.Math.addExact
rbackman
parents: 17095
diff changeset
  4508
    no_overflow(0x1, "no");
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  4509
  %}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  4510
%}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  4511
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  4512
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  4513
// Floating comparisons that can be fixed up with extra conditional jumps
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  4514
operand cmpOpUCF2() %{
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  4515
  match(Bool);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  4516
  predicate(n->as_Bool()->_test._test == BoolTest::ne ||
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  4517
            n->as_Bool()->_test._test == BoolTest::eq);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  4518
  format %{ "" %}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  4519
  interface(COND_INTER) %{
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  4520
    equal(0x4, "e");
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  4521
    not_equal(0x5, "ne");
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  4522
    less(0x2, "b");
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  4523
    greater_equal(0x3, "nb");
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  4524
    less_equal(0x6, "be");
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  4525
    greater(0x7, "nbe");
20289
35d78de0c547 8024924: Intrinsify java.lang.Math.addExact
rbackman
parents: 17095
diff changeset
  4526
    overflow(0x0, "o");
35d78de0c547 8024924: Intrinsify java.lang.Math.addExact
rbackman
parents: 17095
diff changeset
  4527
    no_overflow(0x1, "no");
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4528
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4529
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4530
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4531
// Comparison Code for FP conditional move
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4532
operand cmpOp_fcmov() %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4533
  match(Bool);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4534
20289
35d78de0c547 8024924: Intrinsify java.lang.Math.addExact
rbackman
parents: 17095
diff changeset
  4535
  predicate(n->as_Bool()->_test._test != BoolTest::overflow &&
35d78de0c547 8024924: Intrinsify java.lang.Math.addExact
rbackman
parents: 17095
diff changeset
  4536
            n->as_Bool()->_test._test != BoolTest::no_overflow);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4537
  format %{ "" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4538
  interface(COND_INTER) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4539
    equal        (0x0C8);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4540
    not_equal    (0x1C8);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4541
    less         (0x0C0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4542
    greater_equal(0x1C0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4543
    less_equal   (0x0D0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4544
    greater      (0x1D0);
20289
35d78de0c547 8024924: Intrinsify java.lang.Math.addExact
rbackman
parents: 17095
diff changeset
  4545
    overflow(0x0, "o"); // not really supported by the instruction
35d78de0c547 8024924: Intrinsify java.lang.Math.addExact
rbackman
parents: 17095
diff changeset
  4546
    no_overflow(0x1, "no"); // not really supported by the instruction
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4547
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4548
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4549
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4550
// Comparision Code used in long compares
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4551
operand cmpOp_commute() %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4552
  match(Bool);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4553
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4554
  format %{ "" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4555
  interface(COND_INTER) %{
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  4556
    equal(0x4, "e");
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  4557
    not_equal(0x5, "ne");
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  4558
    less(0xF, "g");
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  4559
    greater_equal(0xE, "le");
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  4560
    less_equal(0xD, "ge");
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  4561
    greater(0xC, "l");
20289
35d78de0c547 8024924: Intrinsify java.lang.Math.addExact
rbackman
parents: 17095
diff changeset
  4562
    overflow(0x0, "o");
35d78de0c547 8024924: Intrinsify java.lang.Math.addExact
rbackman
parents: 17095
diff changeset
  4563
    no_overflow(0x1, "no");
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4564
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4565
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4566
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4567
//----------OPERAND CLASSES----------------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4568
// Operand Classes are groups of operands that are used as to simplify
2131
98f9cef66a34 6810672: Comment typos
twisti
parents: 2034
diff changeset
  4569
// instruction definitions by not requiring the AD writer to specify separate
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4570
// instructions for every form of operand when the instruction accepts
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4571
// multiple operand types with the same basic encoding and format.  The classic
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4572
// case of this is memory operands.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4573
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4574
opclass memory(direct, indirect, indOffset8, indOffset32, indOffset32X, indIndexOffset,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4575
               indIndex, indIndexScale, indIndexScaleOffset);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4576
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4577
// Long memory operations are encoded in 2 instructions and a +4 offset.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4578
// This means some kind of offset is always required and you cannot use
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4579
// an oop as the offset (done when working on static globals).
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4580
opclass long_memory(direct, indirect, indOffset8, indOffset32, indIndexOffset,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4581
                    indIndex, indIndexScale, indIndexScaleOffset);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4582
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4583
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4584
//----------PIPELINE-----------------------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4585
// Rules which define the behavior of the target architectures pipeline.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4586
pipeline %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4587
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4588
//----------ATTRIBUTES---------------------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4589
attributes %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4590
  variable_size_instructions;        // Fixed size instructions
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4591
  max_instructions_per_bundle = 3;   // Up to 3 instructions per bundle
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4592
  instruction_unit_size = 1;         // An instruction is 1 bytes long
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4593
  instruction_fetch_unit_size = 16;  // The processor fetches one line
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4594
  instruction_fetch_units = 1;       // of 16 bytes
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4595
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4596
  // List of nop instructions
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4597
  nops( MachNop );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4598
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4599
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4600
//----------RESOURCES----------------------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4601
// Resources are the functional units available to the machine
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4602
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4603
// Generic P2/P3 pipeline
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4604
// 3 decoders, only D0 handles big operands; a "bundle" is the limit of
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4605
// 3 instructions decoded per cycle.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4606
// 2 load/store ops per cycle, 1 branch, 1 FPU,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4607
// 2 ALU op, only ALU0 handles mul/div instructions.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4608
resources( D0, D1, D2, DECODE = D0 | D1 | D2,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4609
           MS0, MS1, MEM = MS0 | MS1,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4610
           BR, FPU,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4611
           ALU0, ALU1, ALU = ALU0 | ALU1 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4612
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4613
//----------PIPELINE DESCRIPTION-----------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4614
// Pipeline Description specifies the stages in the machine's pipeline
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4615
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4616
// Generic P2/P3 pipeline
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4617
pipe_desc(S0, S1, S2, S3, S4, S5);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4618
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4619
//----------PIPELINE CLASSES---------------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4620
// Pipeline Classes describe the stages in which input and output are
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4621
// referenced by the hardware pipeline.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4622
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4623
// Naming convention: ialu or fpu
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4624
// Then: _reg
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4625
// Then: _reg if there is a 2nd register
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4626
// Then: _long if it's a pair of instructions implementing a long
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4627
// Then: _fat if it requires the big decoder
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4628
//   Or: _mem if it requires the big decoder and a memory unit.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4629
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4630
// Integer ALU reg operation
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  4631
pipe_class ialu_reg(rRegI dst) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4632
    single_instruction;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4633
    dst    : S4(write);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4634
    dst    : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4635
    DECODE : S0;        // any decoder
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4636
    ALU    : S3;        // any alu
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4637
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4638
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4639
// Long ALU reg operation
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4640
pipe_class ialu_reg_long(eRegL dst) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4641
    instruction_count(2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4642
    dst    : S4(write);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4643
    dst    : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4644
    DECODE : S0(2);     // any 2 decoders
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4645
    ALU    : S3(2);     // both alus
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4646
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4647
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4648
// Integer ALU reg operation using big decoder
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  4649
pipe_class ialu_reg_fat(rRegI dst) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4650
    single_instruction;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4651
    dst    : S4(write);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4652
    dst    : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4653
    D0     : S0;        // big decoder only
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4654
    ALU    : S3;        // any alu
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4655
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4656
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4657
// Long ALU reg operation using big decoder
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4658
pipe_class ialu_reg_long_fat(eRegL dst) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4659
    instruction_count(2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4660
    dst    : S4(write);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4661
    dst    : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4662
    D0     : S0(2);     // big decoder only; twice
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4663
    ALU    : S3(2);     // any 2 alus
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4664
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4665
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4666
// Integer ALU reg-reg operation
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  4667
pipe_class ialu_reg_reg(rRegI dst, rRegI src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4668
    single_instruction;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4669
    dst    : S4(write);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4670
    src    : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4671
    DECODE : S0;        // any decoder
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4672
    ALU    : S3;        // any alu
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4673
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4674
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4675
// Long ALU reg-reg operation
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4676
pipe_class ialu_reg_reg_long(eRegL dst, eRegL src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4677
    instruction_count(2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4678
    dst    : S4(write);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4679
    src    : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4680
    DECODE : S0(2);     // any 2 decoders
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4681
    ALU    : S3(2);     // both alus
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4682
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4683
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4684
// Integer ALU reg-reg operation
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  4685
pipe_class ialu_reg_reg_fat(rRegI dst, memory src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4686
    single_instruction;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4687
    dst    : S4(write);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4688
    src    : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4689
    D0     : S0;        // big decoder only
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4690
    ALU    : S3;        // any alu
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4691
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4692
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4693
// Long ALU reg-reg operation
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4694
pipe_class ialu_reg_reg_long_fat(eRegL dst, eRegL src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4695
    instruction_count(2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4696
    dst    : S4(write);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4697
    src    : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4698
    D0     : S0(2);     // big decoder only; twice
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4699
    ALU    : S3(2);     // both alus
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4700
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4701
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4702
// Integer ALU reg-mem operation
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  4703
pipe_class ialu_reg_mem(rRegI dst, memory mem) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4704
    single_instruction;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4705
    dst    : S5(write);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4706
    mem    : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4707
    D0     : S0;        // big decoder only
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4708
    ALU    : S4;        // any alu
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4709
    MEM    : S3;        // any mem
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4710
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4711
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4712
// Long ALU reg-mem operation
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4713
pipe_class ialu_reg_long_mem(eRegL dst, load_long_memory mem) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4714
    instruction_count(2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4715
    dst    : S5(write);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4716
    mem    : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4717
    D0     : S0(2);     // big decoder only; twice
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4718
    ALU    : S4(2);     // any 2 alus
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4719
    MEM    : S3(2);     // both mems
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4720
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4721
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4722
// Integer mem operation (prefetch)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4723
pipe_class ialu_mem(memory mem)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4724
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4725
    single_instruction;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4726
    mem    : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4727
    D0     : S0;        // big decoder only
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4728
    MEM    : S3;        // any mem
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4729
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4730
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4731
// Integer Store to Memory
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  4732
pipe_class ialu_mem_reg(memory mem, rRegI src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4733
    single_instruction;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4734
    mem    : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4735
    src    : S5(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4736
    D0     : S0;        // big decoder only
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4737
    ALU    : S4;        // any alu
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4738
    MEM    : S3;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4739
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4740
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4741
// Long Store to Memory
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4742
pipe_class ialu_mem_long_reg(memory mem, eRegL src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4743
    instruction_count(2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4744
    mem    : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4745
    src    : S5(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4746
    D0     : S0(2);     // big decoder only; twice
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4747
    ALU    : S4(2);     // any 2 alus
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4748
    MEM    : S3(2);     // Both mems
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4749
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4750
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4751
// Integer Store to Memory
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4752
pipe_class ialu_mem_imm(memory mem) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4753
    single_instruction;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4754
    mem    : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4755
    D0     : S0;        // big decoder only
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4756
    ALU    : S4;        // any alu
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4757
    MEM    : S3;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4758
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4759
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4760
// Integer ALU0 reg-reg operation
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  4761
pipe_class ialu_reg_reg_alu0(rRegI dst, rRegI src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4762
    single_instruction;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4763
    dst    : S4(write);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4764
    src    : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4765
    D0     : S0;        // Big decoder only
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4766
    ALU0   : S3;        // only alu0
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4767
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4768
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4769
// Integer ALU0 reg-mem operation
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  4770
pipe_class ialu_reg_mem_alu0(rRegI dst, memory mem) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4771
    single_instruction;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4772
    dst    : S5(write);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4773
    mem    : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4774
    D0     : S0;        // big decoder only
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4775
    ALU0   : S4;        // ALU0 only
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4776
    MEM    : S3;        // any mem
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4777
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4778
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4779
// Integer ALU reg-reg operation
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  4780
pipe_class ialu_cr_reg_reg(eFlagsReg cr, rRegI src1, rRegI src2) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4781
    single_instruction;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4782
    cr     : S4(write);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4783
    src1   : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4784
    src2   : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4785
    DECODE : S0;        // any decoder
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4786
    ALU    : S3;        // any alu
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4787
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4788
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4789
// Integer ALU reg-imm operation
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  4790
pipe_class ialu_cr_reg_imm(eFlagsReg cr, rRegI src1) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4791
    single_instruction;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4792
    cr     : S4(write);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4793
    src1   : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4794
    DECODE : S0;        // any decoder
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4795
    ALU    : S3;        // any alu
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4796
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4797
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4798
// Integer ALU reg-mem operation
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  4799
pipe_class ialu_cr_reg_mem(eFlagsReg cr, rRegI src1, memory src2) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4800
    single_instruction;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4801
    cr     : S4(write);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4802
    src1   : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4803
    src2   : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4804
    D0     : S0;        // big decoder only
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4805
    ALU    : S4;        // any alu
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4806
    MEM    : S3;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4807
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4808
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4809
// Conditional move reg-reg
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  4810
pipe_class pipe_cmplt( rRegI p, rRegI q, rRegI y ) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4811
    instruction_count(4);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4812
    y      : S4(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4813
    q      : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4814
    p      : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4815
    DECODE : S0(4);     // any decoder
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4816
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4817
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4818
// Conditional move reg-reg
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  4819
pipe_class pipe_cmov_reg( rRegI dst, rRegI src, eFlagsReg cr ) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4820
    single_instruction;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4821
    dst    : S4(write);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4822
    src    : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4823
    cr     : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4824
    DECODE : S0;        // any decoder
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4825
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4826
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4827
// Conditional move reg-mem
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  4828
pipe_class pipe_cmov_mem( eFlagsReg cr, rRegI dst, memory src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4829
    single_instruction;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4830
    dst    : S4(write);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4831
    src    : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4832
    cr     : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4833
    DECODE : S0;        // any decoder
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4834
    MEM    : S3;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4835
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4836
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4837
// Conditional move reg-reg long
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4838
pipe_class pipe_cmov_reg_long( eFlagsReg cr, eRegL dst, eRegL src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4839
    single_instruction;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4840
    dst    : S4(write);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4841
    src    : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4842
    cr     : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4843
    DECODE : S0(2);     // any 2 decoders
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4844
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4845
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4846
// Conditional move double reg-reg
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  4847
pipe_class pipe_cmovDPR_reg( eFlagsReg cr, regDPR1 dst, regDPR src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4848
    single_instruction;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4849
    dst    : S4(write);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4850
    src    : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4851
    cr     : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4852
    DECODE : S0;        // any decoder
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4853
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4854
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4855
// Float reg-reg operation
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  4856
pipe_class fpu_reg(regDPR dst) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4857
    instruction_count(2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4858
    dst    : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4859
    DECODE : S0(2);     // any 2 decoders
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4860
    FPU    : S3;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4861
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4862
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4863
// Float reg-reg operation
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  4864
pipe_class fpu_reg_reg(regDPR dst, regDPR src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4865
    instruction_count(2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4866
    dst    : S4(write);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4867
    src    : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4868
    DECODE : S0(2);     // any 2 decoders
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4869
    FPU    : S3;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4870
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4871
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4872
// Float reg-reg operation
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  4873
pipe_class fpu_reg_reg_reg(regDPR dst, regDPR src1, regDPR src2) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4874
    instruction_count(3);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4875
    dst    : S4(write);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4876
    src1   : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4877
    src2   : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4878
    DECODE : S0(3);     // any 3 decoders
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4879
    FPU    : S3(2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4880
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4881
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4882
// Float reg-reg operation
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  4883
pipe_class fpu_reg_reg_reg_reg(regDPR dst, regDPR src1, regDPR src2, regDPR src3) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4884
    instruction_count(4);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4885
    dst    : S4(write);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4886
    src1   : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4887
    src2   : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4888
    src3   : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4889
    DECODE : S0(4);     // any 3 decoders
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4890
    FPU    : S3(2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4891
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4892
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4893
// Float reg-reg operation
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  4894
pipe_class fpu_reg_mem_reg_reg(regDPR dst, memory src1, regDPR src2, regDPR src3) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4895
    instruction_count(4);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4896
    dst    : S4(write);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4897
    src1   : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4898
    src2   : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4899
    src3   : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4900
    DECODE : S1(3);     // any 3 decoders
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4901
    D0     : S0;        // Big decoder only
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4902
    FPU    : S3(2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4903
    MEM    : S3;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4904
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4905
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4906
// Float reg-mem operation
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  4907
pipe_class fpu_reg_mem(regDPR dst, memory mem) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4908
    instruction_count(2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4909
    dst    : S5(write);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4910
    mem    : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4911
    D0     : S0;        // big decoder only
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4912
    DECODE : S1;        // any decoder for FPU POP
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4913
    FPU    : S4;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4914
    MEM    : S3;        // any mem
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4915
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4916
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4917
// Float reg-mem operation
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  4918
pipe_class fpu_reg_reg_mem(regDPR dst, regDPR src1, memory mem) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4919
    instruction_count(3);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4920
    dst    : S5(write);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4921
    src1   : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4922
    mem    : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4923
    D0     : S0;        // big decoder only
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4924
    DECODE : S1(2);     // any decoder for FPU POP
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4925
    FPU    : S4;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4926
    MEM    : S3;        // any mem
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4927
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4928
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4929
// Float mem-reg operation
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  4930
pipe_class fpu_mem_reg(memory mem, regDPR src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4931
    instruction_count(2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4932
    src    : S5(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4933
    mem    : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4934
    DECODE : S0;        // any decoder for FPU PUSH
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4935
    D0     : S1;        // big decoder only
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4936
    FPU    : S4;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4937
    MEM    : S3;        // any mem
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4938
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4939
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  4940
pipe_class fpu_mem_reg_reg(memory mem, regDPR src1, regDPR src2) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4941
    instruction_count(3);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4942
    src1   : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4943
    src2   : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4944
    mem    : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4945
    DECODE : S0(2);     // any decoder for FPU PUSH
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4946
    D0     : S1;        // big decoder only
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4947
    FPU    : S4;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4948
    MEM    : S3;        // any mem
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4949
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4950
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  4951
pipe_class fpu_mem_reg_mem(memory mem, regDPR src1, memory src2) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4952
    instruction_count(3);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4953
    src1   : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4954
    src2   : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4955
    mem    : S4(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4956
    DECODE : S0;        // any decoder for FPU PUSH
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4957
    D0     : S0(2);     // big decoder only
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4958
    FPU    : S4;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4959
    MEM    : S3(2);     // any mem
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4960
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4961
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4962
pipe_class fpu_mem_mem(memory dst, memory src1) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4963
    instruction_count(2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4964
    src1   : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4965
    dst    : S4(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4966
    D0     : S0(2);     // big decoder only
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4967
    MEM    : S3(2);     // any mem
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4968
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4969
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4970
pipe_class fpu_mem_mem_mem(memory dst, memory src1, memory src2) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4971
    instruction_count(3);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4972
    src1   : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4973
    src2   : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4974
    dst    : S4(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4975
    D0     : S0(3);     // big decoder only
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4976
    FPU    : S4;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4977
    MEM    : S3(3);     // any mem
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4978
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4979
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  4980
pipe_class fpu_mem_reg_con(memory mem, regDPR src1) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4981
    instruction_count(3);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4982
    src1   : S4(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4983
    mem    : S4(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4984
    DECODE : S0;        // any decoder for FPU PUSH
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4985
    D0     : S0(2);     // big decoder only
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4986
    FPU    : S4;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4987
    MEM    : S3(2);     // any mem
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4988
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4989
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4990
// Float load constant
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  4991
pipe_class fpu_reg_con(regDPR dst) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4992
    instruction_count(2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4993
    dst    : S5(write);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4994
    D0     : S0;        // big decoder only for the load
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4995
    DECODE : S1;        // any decoder for FPU POP
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4996
    FPU    : S4;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4997
    MEM    : S3;        // any mem
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4998
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4999
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5000
// Float load constant
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  5001
pipe_class fpu_reg_reg_con(regDPR dst, regDPR src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5002
    instruction_count(3);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5003
    dst    : S5(write);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5004
    src    : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5005
    D0     : S0;        // big decoder only for the load
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5006
    DECODE : S1(2);     // any decoder for FPU POP
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5007
    FPU    : S4;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5008
    MEM    : S3;        // any mem
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5009
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5010
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5011
// UnConditional branch
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5012
pipe_class pipe_jmp( label labl ) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5013
    single_instruction;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5014
    BR   : S3;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5015
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5016
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5017
// Conditional branch
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5018
pipe_class pipe_jcc( cmpOp cmp, eFlagsReg cr, label labl ) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5019
    single_instruction;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5020
    cr    : S1(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5021
    BR    : S3;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5022
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5023
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5024
// Allocation idiom
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5025
pipe_class pipe_cmpxchg( eRegP dst, eRegP heap_ptr ) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5026
    instruction_count(1); force_serialization;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5027
    fixed_latency(6);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5028
    heap_ptr : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5029
    DECODE   : S0(3);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5030
    D0       : S2;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5031
    MEM      : S3;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5032
    ALU      : S3(2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5033
    dst      : S5(write);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5034
    BR       : S5;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5035
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5036
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5037
// Generic big/slow expanded idiom
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5038
pipe_class pipe_slow(  ) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5039
    instruction_count(10); multiple_bundles; force_serialization;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5040
    fixed_latency(100);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5041
    D0  : S0(2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5042
    MEM : S3(2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5043
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5044
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5045
// The real do-nothing guy
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5046
pipe_class empty( ) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5047
    instruction_count(0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5048
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5049
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5050
// Define the class for the Nop node
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5051
define %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5052
   MachNop = empty;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5053
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5054
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5055
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5056
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5057
//----------INSTRUCTIONS-------------------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5058
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5059
// match      -- States which machine-independent subtree may be replaced
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5060
//               by this instruction.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5061
// ins_cost   -- The estimated cost of this instruction is used by instruction
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5062
//               selection to identify a minimum cost tree of machine
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5063
//               instructions that matches a tree of machine-independent
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5064
//               instructions.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5065
// format     -- A string providing the disassembly for this instruction.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5066
//               The value of an instruction's operand may be inserted
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5067
//               by referring to it with a '$' prefix.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5068
// opcode     -- Three instruction opcodes may be provided.  These are referred
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5069
//               to within an encode class as $primary, $secondary, and $tertiary
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5070
//               respectively.  The primary opcode is commonly used to
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5071
//               indicate the type of machine instruction, while secondary
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5072
//               and tertiary are often used for prefix options or addressing
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5073
//               modes.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5074
// ins_encode -- A list of encode classes with parameters. The encode class
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5075
//               name must have been defined in an 'enc_class' specification
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5076
//               in the encode section of the architecture description.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5077
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5078
//----------BSWAP-Instruction--------------------------------------------------
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  5079
instruct bytes_reverse_int(rRegI dst) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5080
  match(Set dst (ReverseBytesI dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5081
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5082
  format %{ "BSWAP  $dst" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5083
  opcode(0x0F, 0xC8);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5084
  ins_encode( OpcP, OpcSReg(dst) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5085
  ins_pipe( ialu_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5086
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5087
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5088
instruct bytes_reverse_long(eRegL dst) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5089
  match(Set dst (ReverseBytesL dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5090
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5091
  format %{ "BSWAP  $dst.lo\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5092
            "BSWAP  $dst.hi\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5093
            "XCHG   $dst.lo $dst.hi" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5094
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5095
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5096
  ins_encode( bswap_long_bytes(dst) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5097
  ins_pipe( ialu_reg_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5098
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5099
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  5100
instruct bytes_reverse_unsigned_short(rRegI dst, eFlagsReg cr) %{
5352
cee8f7acb7bc 6946040: add intrinsic for short and char reverseBytes
never
parents: 5025
diff changeset
  5101
  match(Set dst (ReverseBytesUS dst));
12952
a1f3ff3a89e1 7063674: Wrong results from basic comparisons after calls to Long.bitCount(long)
twisti
parents: 12739
diff changeset
  5102
  effect(KILL cr);
5352
cee8f7acb7bc 6946040: add intrinsic for short and char reverseBytes
never
parents: 5025
diff changeset
  5103
30624
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
  5104
  format %{ "BSWAP  $dst\n\t"
5352
cee8f7acb7bc 6946040: add intrinsic for short and char reverseBytes
never
parents: 5025
diff changeset
  5105
            "SHR    $dst,16\n\t" %}
cee8f7acb7bc 6946040: add intrinsic for short and char reverseBytes
never
parents: 5025
diff changeset
  5106
  ins_encode %{
cee8f7acb7bc 6946040: add intrinsic for short and char reverseBytes
never
parents: 5025
diff changeset
  5107
    __ bswapl($dst$$Register);
30624
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
  5108
    __ shrl($dst$$Register, 16);
5352
cee8f7acb7bc 6946040: add intrinsic for short and char reverseBytes
never
parents: 5025
diff changeset
  5109
  %}
cee8f7acb7bc 6946040: add intrinsic for short and char reverseBytes
never
parents: 5025
diff changeset
  5110
  ins_pipe( ialu_reg );
cee8f7acb7bc 6946040: add intrinsic for short and char reverseBytes
never
parents: 5025
diff changeset
  5111
%}
cee8f7acb7bc 6946040: add intrinsic for short and char reverseBytes
never
parents: 5025
diff changeset
  5112
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  5113
instruct bytes_reverse_short(rRegI dst, eFlagsReg cr) %{
5352
cee8f7acb7bc 6946040: add intrinsic for short and char reverseBytes
never
parents: 5025
diff changeset
  5114
  match(Set dst (ReverseBytesS dst));
12952
a1f3ff3a89e1 7063674: Wrong results from basic comparisons after calls to Long.bitCount(long)
twisti
parents: 12739
diff changeset
  5115
  effect(KILL cr);
5352
cee8f7acb7bc 6946040: add intrinsic for short and char reverseBytes
never
parents: 5025
diff changeset
  5116
30624
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
  5117
  format %{ "BSWAP  $dst\n\t"
5352
cee8f7acb7bc 6946040: add intrinsic for short and char reverseBytes
never
parents: 5025
diff changeset
  5118
            "SAR    $dst,16\n\t" %}
cee8f7acb7bc 6946040: add intrinsic for short and char reverseBytes
never
parents: 5025
diff changeset
  5119
  ins_encode %{
cee8f7acb7bc 6946040: add intrinsic for short and char reverseBytes
never
parents: 5025
diff changeset
  5120
    __ bswapl($dst$$Register);
30624
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
  5121
    __ sarl($dst$$Register, 16);
5352
cee8f7acb7bc 6946040: add intrinsic for short and char reverseBytes
never
parents: 5025
diff changeset
  5122
  %}
cee8f7acb7bc 6946040: add intrinsic for short and char reverseBytes
never
parents: 5025
diff changeset
  5123
  ins_pipe( ialu_reg );
cee8f7acb7bc 6946040: add intrinsic for short and char reverseBytes
never
parents: 5025
diff changeset
  5124
%}
cee8f7acb7bc 6946040: add intrinsic for short and char reverseBytes
never
parents: 5025
diff changeset
  5125
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5126
2862
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5127
//---------- Zeros Count Instructions ------------------------------------------
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5128
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  5129
instruct countLeadingZerosI(rRegI dst, rRegI src, eFlagsReg cr) %{
2862
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5130
  predicate(UseCountLeadingZerosInstruction);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5131
  match(Set dst (CountLeadingZerosI src));
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5132
  effect(KILL cr);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5133
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5134
  format %{ "LZCNT  $dst, $src\t# count leading zeros (int)" %}
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5135
  ins_encode %{
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5136
    __ lzcntl($dst$$Register, $src$$Register);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5137
  %}
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5138
  ins_pipe(ialu_reg);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5139
%}
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5140
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  5141
instruct countLeadingZerosI_bsr(rRegI dst, rRegI src, eFlagsReg cr) %{
2862
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5142
  predicate(!UseCountLeadingZerosInstruction);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5143
  match(Set dst (CountLeadingZerosI src));
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5144
  effect(KILL cr);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5145
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5146
  format %{ "BSR    $dst, $src\t# count leading zeros (int)\n\t"
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5147
            "JNZ    skip\n\t"
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5148
            "MOV    $dst, -1\n"
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5149
      "skip:\n\t"
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5150
            "NEG    $dst\n\t"
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5151
            "ADD    $dst, 31" %}
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5152
  ins_encode %{
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5153
    Register Rdst = $dst$$Register;
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5154
    Register Rsrc = $src$$Register;
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5155
    Label skip;
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5156
    __ bsrl(Rdst, Rsrc);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5157
    __ jccb(Assembler::notZero, skip);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5158
    __ movl(Rdst, -1);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5159
    __ bind(skip);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5160
    __ negl(Rdst);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5161
    __ addl(Rdst, BitsPerInt - 1);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5162
  %}
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5163
  ins_pipe(ialu_reg);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5164
%}
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5165
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  5166
instruct countLeadingZerosL(rRegI dst, eRegL src, eFlagsReg cr) %{
2862
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5167
  predicate(UseCountLeadingZerosInstruction);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5168
  match(Set dst (CountLeadingZerosL src));
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5169
  effect(TEMP dst, KILL cr);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5170
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5171
  format %{ "LZCNT  $dst, $src.hi\t# count leading zeros (long)\n\t"
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5172
            "JNC    done\n\t"
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5173
            "LZCNT  $dst, $src.lo\n\t"
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5174
            "ADD    $dst, 32\n"
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5175
      "done:" %}
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5176
  ins_encode %{
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5177
    Register Rdst = $dst$$Register;
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5178
    Register Rsrc = $src$$Register;
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5179
    Label done;
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5180
    __ lzcntl(Rdst, HIGH_FROM_LOW(Rsrc));
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5181
    __ jccb(Assembler::carryClear, done);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5182
    __ lzcntl(Rdst, Rsrc);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5183
    __ addl(Rdst, BitsPerInt);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5184
    __ bind(done);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5185
  %}
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5186
  ins_pipe(ialu_reg);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5187
%}
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5188
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  5189
instruct countLeadingZerosL_bsr(rRegI dst, eRegL src, eFlagsReg cr) %{
2862
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5190
  predicate(!UseCountLeadingZerosInstruction);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5191
  match(Set dst (CountLeadingZerosL src));
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5192
  effect(TEMP dst, KILL cr);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5193
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5194
  format %{ "BSR    $dst, $src.hi\t# count leading zeros (long)\n\t"
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5195
            "JZ     msw_is_zero\n\t"
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5196
            "ADD    $dst, 32\n\t"
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5197
            "JMP    not_zero\n"
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5198
      "msw_is_zero:\n\t"
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5199
            "BSR    $dst, $src.lo\n\t"
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5200
            "JNZ    not_zero\n\t"
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5201
            "MOV    $dst, -1\n"
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5202
      "not_zero:\n\t"
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5203
            "NEG    $dst\n\t"
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5204
            "ADD    $dst, 63\n" %}
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5205
 ins_encode %{
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5206
    Register Rdst = $dst$$Register;
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5207
    Register Rsrc = $src$$Register;
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5208
    Label msw_is_zero;
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5209
    Label not_zero;
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5210
    __ bsrl(Rdst, HIGH_FROM_LOW(Rsrc));
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5211
    __ jccb(Assembler::zero, msw_is_zero);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5212
    __ addl(Rdst, BitsPerInt);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5213
    __ jmpb(not_zero);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5214
    __ bind(msw_is_zero);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5215
    __ bsrl(Rdst, Rsrc);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5216
    __ jccb(Assembler::notZero, not_zero);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5217
    __ movl(Rdst, -1);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5218
    __ bind(not_zero);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5219
    __ negl(Rdst);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5220
    __ addl(Rdst, BitsPerLong - 1);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5221
  %}
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5222
  ins_pipe(ialu_reg);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5223
%}
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5224
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  5225
instruct countTrailingZerosI(rRegI dst, rRegI src, eFlagsReg cr) %{
23220
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  5226
  predicate(UseCountTrailingZerosInstruction);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  5227
  match(Set dst (CountTrailingZerosI src));
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  5228
  effect(KILL cr);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  5229
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  5230
  format %{ "TZCNT    $dst, $src\t# count trailing zeros (int)" %}
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  5231
  ins_encode %{
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  5232
    __ tzcntl($dst$$Register, $src$$Register);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  5233
  %}
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  5234
  ins_pipe(ialu_reg);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  5235
%}
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  5236
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  5237
instruct countTrailingZerosI_bsf(rRegI dst, rRegI src, eFlagsReg cr) %{
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  5238
  predicate(!UseCountTrailingZerosInstruction);
2862
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5239
  match(Set dst (CountTrailingZerosI src));
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5240
  effect(KILL cr);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5241
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5242
  format %{ "BSF    $dst, $src\t# count trailing zeros (int)\n\t"
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5243
            "JNZ    done\n\t"
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5244
            "MOV    $dst, 32\n"
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5245
      "done:" %}
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5246
  ins_encode %{
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5247
    Register Rdst = $dst$$Register;
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5248
    Label done;
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5249
    __ bsfl(Rdst, $src$$Register);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5250
    __ jccb(Assembler::notZero, done);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5251
    __ movl(Rdst, BitsPerInt);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5252
    __ bind(done);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5253
  %}
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5254
  ins_pipe(ialu_reg);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5255
%}
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5256
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  5257
instruct countTrailingZerosL(rRegI dst, eRegL src, eFlagsReg cr) %{
23220
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  5258
  predicate(UseCountTrailingZerosInstruction);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  5259
  match(Set dst (CountTrailingZerosL src));
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  5260
  effect(TEMP dst, KILL cr);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  5261
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  5262
  format %{ "TZCNT  $dst, $src.lo\t# count trailing zeros (long) \n\t"
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  5263
            "JNC    done\n\t"
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  5264
            "TZCNT  $dst, $src.hi\n\t"
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  5265
            "ADD    $dst, 32\n"
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  5266
            "done:" %}
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  5267
  ins_encode %{
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  5268
    Register Rdst = $dst$$Register;
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  5269
    Register Rsrc = $src$$Register;
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  5270
    Label done;
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  5271
    __ tzcntl(Rdst, Rsrc);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  5272
    __ jccb(Assembler::carryClear, done);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  5273
    __ tzcntl(Rdst, HIGH_FROM_LOW(Rsrc));
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  5274
    __ addl(Rdst, BitsPerInt);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  5275
    __ bind(done);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  5276
  %}
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  5277
  ins_pipe(ialu_reg);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  5278
%}
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  5279
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  5280
instruct countTrailingZerosL_bsf(rRegI dst, eRegL src, eFlagsReg cr) %{
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  5281
  predicate(!UseCountTrailingZerosInstruction);
2862
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5282
  match(Set dst (CountTrailingZerosL src));
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5283
  effect(TEMP dst, KILL cr);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5284
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5285
  format %{ "BSF    $dst, $src.lo\t# count trailing zeros (long)\n\t"
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5286
            "JNZ    done\n\t"
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5287
            "BSF    $dst, $src.hi\n\t"
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5288
            "JNZ    msw_not_zero\n\t"
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5289
            "MOV    $dst, 32\n"
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5290
      "msw_not_zero:\n\t"
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5291
            "ADD    $dst, 32\n"
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5292
      "done:" %}
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5293
  ins_encode %{
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5294
    Register Rdst = $dst$$Register;
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5295
    Register Rsrc = $src$$Register;
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5296
    Label msw_not_zero;
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5297
    Label done;
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5298
    __ bsfl(Rdst, Rsrc);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5299
    __ jccb(Assembler::notZero, done);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5300
    __ bsfl(Rdst, HIGH_FROM_LOW(Rsrc));
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5301
    __ jccb(Assembler::notZero, msw_not_zero);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5302
    __ movl(Rdst, BitsPerInt);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5303
    __ bind(msw_not_zero);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5304
    __ addl(Rdst, BitsPerInt);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5305
    __ bind(done);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5306
  %}
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5307
  ins_pipe(ialu_reg);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5308
%}
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5309
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  5310
2255
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2150
diff changeset
  5311
//---------- Population Count Instructions -------------------------------------
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2150
diff changeset
  5312
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  5313
instruct popCountI(rRegI dst, rRegI src, eFlagsReg cr) %{
2255
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2150
diff changeset
  5314
  predicate(UsePopCountInstruction);
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2150
diff changeset
  5315
  match(Set dst (PopCountI src));
12952
a1f3ff3a89e1 7063674: Wrong results from basic comparisons after calls to Long.bitCount(long)
twisti
parents: 12739
diff changeset
  5316
  effect(KILL cr);
2255
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2150
diff changeset
  5317
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2150
diff changeset
  5318
  format %{ "POPCNT $dst, $src" %}
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2150
diff changeset
  5319
  ins_encode %{
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2150
diff changeset
  5320
    __ popcntl($dst$$Register, $src$$Register);
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2150
diff changeset
  5321
  %}
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2150
diff changeset
  5322
  ins_pipe(ialu_reg);
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2150
diff changeset
  5323
%}
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2150
diff changeset
  5324
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  5325
instruct popCountI_mem(rRegI dst, memory mem, eFlagsReg cr) %{
2255
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2150
diff changeset
  5326
  predicate(UsePopCountInstruction);
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2150
diff changeset
  5327
  match(Set dst (PopCountI (LoadI mem)));
12952
a1f3ff3a89e1 7063674: Wrong results from basic comparisons after calls to Long.bitCount(long)
twisti
parents: 12739
diff changeset
  5328
  effect(KILL cr);
2255
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2150
diff changeset
  5329
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2150
diff changeset
  5330
  format %{ "POPCNT $dst, $mem" %}
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2150
diff changeset
  5331
  ins_encode %{
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2150
diff changeset
  5332
    __ popcntl($dst$$Register, $mem$$Address);
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2150
diff changeset
  5333
  %}
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2150
diff changeset
  5334
  ins_pipe(ialu_reg);
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2150
diff changeset
  5335
%}
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2150
diff changeset
  5336
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2150
diff changeset
  5337
// Note: Long.bitCount(long) returns an int.
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  5338
instruct popCountL(rRegI dst, eRegL src, rRegI tmp, eFlagsReg cr) %{
2255
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2150
diff changeset
  5339
  predicate(UsePopCountInstruction);
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2150
diff changeset
  5340
  match(Set dst (PopCountL src));
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2150
diff changeset
  5341
  effect(KILL cr, TEMP tmp, TEMP dst);
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2150
diff changeset
  5342
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2150
diff changeset
  5343
  format %{ "POPCNT $dst, $src.lo\n\t"
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2150
diff changeset
  5344
            "POPCNT $tmp, $src.hi\n\t"
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2150
diff changeset
  5345
            "ADD    $dst, $tmp" %}
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2150
diff changeset
  5346
  ins_encode %{
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2150
diff changeset
  5347
    __ popcntl($dst$$Register, $src$$Register);
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2150
diff changeset
  5348
    __ popcntl($tmp$$Register, HIGH_FROM_LOW($src$$Register));
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2150
diff changeset
  5349
    __ addl($dst$$Register, $tmp$$Register);
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2150
diff changeset
  5350
  %}
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2150
diff changeset
  5351
  ins_pipe(ialu_reg);
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2150
diff changeset
  5352
%}
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2150
diff changeset
  5353
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2150
diff changeset
  5354
// Note: Long.bitCount(long) returns an int.
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  5355
instruct popCountL_mem(rRegI dst, memory mem, rRegI tmp, eFlagsReg cr) %{
2255
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2150
diff changeset
  5356
  predicate(UsePopCountInstruction);
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2150
diff changeset
  5357
  match(Set dst (PopCountL (LoadL mem)));
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2150
diff changeset
  5358
  effect(KILL cr, TEMP tmp, TEMP dst);
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2150
diff changeset
  5359
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2150
diff changeset
  5360
  format %{ "POPCNT $dst, $mem\n\t"
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2150
diff changeset
  5361
            "POPCNT $tmp, $mem+4\n\t"
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2150
diff changeset
  5362
            "ADD    $dst, $tmp" %}
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2150
diff changeset
  5363
  ins_encode %{
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2150
diff changeset
  5364
    //__ popcntl($dst$$Register, $mem$$Address$$first);
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2150
diff changeset
  5365
    //__ popcntl($tmp$$Register, $mem$$Address$$second);
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13485
diff changeset
  5366
    __ popcntl($dst$$Register, Address::make_raw($mem$$base, $mem$$index, $mem$$scale, $mem$$disp, relocInfo::none));
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13485
diff changeset
  5367
    __ popcntl($tmp$$Register, Address::make_raw($mem$$base, $mem$$index, $mem$$scale, $mem$$disp + 4, relocInfo::none));
2255
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2150
diff changeset
  5368
    __ addl($dst$$Register, $tmp$$Register);
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2150
diff changeset
  5369
  %}
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2150
diff changeset
  5370
  ins_pipe(ialu_reg);
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2150
diff changeset
  5371
%}
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2150
diff changeset
  5372
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2150
diff changeset
  5373
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5374
//----------Load/Store/Move Instructions---------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5375
//----------Load Instructions--------------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5376
// Load Byte (8bit signed)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5377
instruct loadB(xRegI dst, memory mem) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5378
  match(Set dst (LoadB mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5379
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5380
  ins_cost(125);
2150
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5381
  format %{ "MOVSX8 $dst,$mem\t# byte" %}
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5382
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5383
  ins_encode %{
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5384
    __ movsbl($dst$$Register, $mem$$Address);
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5385
  %}
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5386
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5387
  ins_pipe(ialu_reg_mem);
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5388
%}
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5389
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5390
// Load Byte (8bit signed) into Long Register
3177
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5391
instruct loadB2L(eRegL dst, memory mem, eFlagsReg cr) %{
2150
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5392
  match(Set dst (ConvI2L (LoadB mem)));
3177
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5393
  effect(KILL cr);
2150
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5394
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5395
  ins_cost(375);
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5396
  format %{ "MOVSX8 $dst.lo,$mem\t# byte -> long\n\t"
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5397
            "MOV    $dst.hi,$dst.lo\n\t"
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5398
            "SAR    $dst.hi,7" %}
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5399
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5400
  ins_encode %{
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5401
    __ movsbl($dst$$Register, $mem$$Address);
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5402
    __ movl(HIGH_FROM_LOW($dst$$Register), $dst$$Register); // This is always a different register.
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5403
    __ sarl(HIGH_FROM_LOW($dst$$Register), 7); // 24+1 MSB are already signed extended.
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5404
  %}
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5405
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5406
  ins_pipe(ialu_reg_mem);
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5407
%}
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5408
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5409
// Load Unsigned Byte (8bit UNsigned)
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5410
instruct loadUB(xRegI dst, memory mem) %{
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5411
  match(Set dst (LoadUB mem));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5412
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5413
  ins_cost(125);
2150
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5414
  format %{ "MOVZX8 $dst,$mem\t# ubyte -> int" %}
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5415
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5416
  ins_encode %{
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5417
    __ movzbl($dst$$Register, $mem$$Address);
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5418
  %}
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5419
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5420
  ins_pipe(ialu_reg_mem);
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5421
%}
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5422
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5423
// Load Unsigned Byte (8 bit UNsigned) into Long Register
3177
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5424
instruct loadUB2L(eRegL dst, memory mem, eFlagsReg cr) %{
2150
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5425
  match(Set dst (ConvI2L (LoadUB mem)));
3177
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5426
  effect(KILL cr);
2150
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5427
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5428
  ins_cost(250);
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5429
  format %{ "MOVZX8 $dst.lo,$mem\t# ubyte -> long\n\t"
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5430
            "XOR    $dst.hi,$dst.hi" %}
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5431
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5432
  ins_encode %{
3177
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5433
    Register Rdst = $dst$$Register;
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5434
    __ movzbl(Rdst, $mem$$Address);
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5435
    __ xorl(HIGH_FROM_LOW(Rdst), HIGH_FROM_LOW(Rdst));
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5436
  %}
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5437
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5438
  ins_pipe(ialu_reg_mem);
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5439
%}
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5440
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5441
// Load Unsigned Byte (8 bit UNsigned) with mask into Long Register
31047
50c0dc40661c 8001622: loadUB2L_immI8 & loadUS2L_immI16 rules don't match some 8-bit/16-bit masks
vlivanov
parents: 30624
diff changeset
  5442
instruct loadUB2L_immI(eRegL dst, memory mem, immI mask, eFlagsReg cr) %{
3177
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5443
  match(Set dst (ConvI2L (AndI (LoadUB mem) mask)));
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5444
  effect(KILL cr);
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5445
31047
50c0dc40661c 8001622: loadUB2L_immI8 & loadUS2L_immI16 rules don't match some 8-bit/16-bit masks
vlivanov
parents: 30624
diff changeset
  5446
  format %{ "MOVZX8 $dst.lo,$mem\t# ubyte & 32-bit mask -> long\n\t"
3177
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5447
            "XOR    $dst.hi,$dst.hi\n\t"
31047
50c0dc40661c 8001622: loadUB2L_immI8 & loadUS2L_immI16 rules don't match some 8-bit/16-bit masks
vlivanov
parents: 30624
diff changeset
  5448
            "AND    $dst.lo,right_n_bits($mask, 8)" %}
3177
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5449
  ins_encode %{
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5450
    Register Rdst = $dst$$Register;
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5451
    __ movzbl(Rdst, $mem$$Address);
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5452
    __ xorl(HIGH_FROM_LOW(Rdst), HIGH_FROM_LOW(Rdst));
31047
50c0dc40661c 8001622: loadUB2L_immI8 & loadUS2L_immI16 rules don't match some 8-bit/16-bit masks
vlivanov
parents: 30624
diff changeset
  5453
    __ andl(Rdst, $mask$$constant & right_n_bits(8));
3177
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5454
  %}
2150
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5455
  ins_pipe(ialu_reg_mem);
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5456
%}
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5457
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5458
// Load Short (16bit signed)
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  5459
instruct loadS(rRegI dst, memory mem) %{
2150
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5460
  match(Set dst (LoadS mem));
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5461
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5462
  ins_cost(125);
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5463
  format %{ "MOVSX  $dst,$mem\t# short" %}
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5464
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5465
  ins_encode %{
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5466
    __ movswl($dst$$Register, $mem$$Address);
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5467
  %}
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5468
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5469
  ins_pipe(ialu_reg_mem);
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5470
%}
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5471
2872
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  5472
// Load Short (16 bit signed) to Byte (8 bit signed)
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  5473
instruct loadS2B(rRegI dst, memory mem, immI_24 twentyfour) %{
2872
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  5474
  match(Set dst (RShiftI (LShiftI (LoadS mem) twentyfour) twentyfour));
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  5475
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  5476
  ins_cost(125);
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  5477
  format %{ "MOVSX  $dst, $mem\t# short -> byte" %}
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  5478
  ins_encode %{
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  5479
    __ movsbl($dst$$Register, $mem$$Address);
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  5480
  %}
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  5481
  ins_pipe(ialu_reg_mem);
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  5482
%}
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  5483
2150
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5484
// Load Short (16bit signed) into Long Register
3177
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5485
instruct loadS2L(eRegL dst, memory mem, eFlagsReg cr) %{
2150
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5486
  match(Set dst (ConvI2L (LoadS mem)));
3177
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5487
  effect(KILL cr);
2150
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5488
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5489
  ins_cost(375);
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5490
  format %{ "MOVSX  $dst.lo,$mem\t# short -> long\n\t"
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5491
            "MOV    $dst.hi,$dst.lo\n\t"
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5492
            "SAR    $dst.hi,15" %}
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5493
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5494
  ins_encode %{
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5495
    __ movswl($dst$$Register, $mem$$Address);
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5496
    __ movl(HIGH_FROM_LOW($dst$$Register), $dst$$Register); // This is always a different register.
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5497
    __ sarl(HIGH_FROM_LOW($dst$$Register), 15); // 16+1 MSB are already signed extended.
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5498
  %}
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5499
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5500
  ins_pipe(ialu_reg_mem);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5501
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5502
2022
28ce8115a91d 6796746: rename LoadC (char) opcode class to LoadUS (unsigned short)
twisti
parents: 1500
diff changeset
  5503
// Load Unsigned Short/Char (16bit unsigned)
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  5504
instruct loadUS(rRegI dst, memory mem) %{
2022
28ce8115a91d 6796746: rename LoadC (char) opcode class to LoadUS (unsigned short)
twisti
parents: 1500
diff changeset
  5505
  match(Set dst (LoadUS mem));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5506
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5507
  ins_cost(125);
2150
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5508
  format %{ "MOVZX  $dst,$mem\t# ushort/char -> int" %}
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5509
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5510
  ins_encode %{
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5511
    __ movzwl($dst$$Register, $mem$$Address);
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5512
  %}
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5513
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5514
  ins_pipe(ialu_reg_mem);
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5515
%}
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5516
2872
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  5517
// Load Unsigned Short/Char (16 bit UNsigned) to Byte (8 bit signed)
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  5518
instruct loadUS2B(rRegI dst, memory mem, immI_24 twentyfour) %{
2872
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  5519
  match(Set dst (RShiftI (LShiftI (LoadUS mem) twentyfour) twentyfour));
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  5520
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  5521
  ins_cost(125);
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  5522
  format %{ "MOVSX  $dst, $mem\t# ushort -> byte" %}
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  5523
  ins_encode %{
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  5524
    __ movsbl($dst$$Register, $mem$$Address);
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  5525
  %}
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  5526
  ins_pipe(ialu_reg_mem);
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  5527
%}
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  5528
2150
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5529
// Load Unsigned Short/Char (16 bit UNsigned) into Long Register
3177
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5530
instruct loadUS2L(eRegL dst, memory mem, eFlagsReg cr) %{
2150
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5531
  match(Set dst (ConvI2L (LoadUS mem)));
3177
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5532
  effect(KILL cr);
2150
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5533
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5534
  ins_cost(250);
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5535
  format %{ "MOVZX  $dst.lo,$mem\t# ushort/char -> long\n\t"
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5536
            "XOR    $dst.hi,$dst.hi" %}
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5537
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5538
  ins_encode %{
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5539
    __ movzwl($dst$$Register, $mem$$Address);
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5540
    __ xorl(HIGH_FROM_LOW($dst$$Register), HIGH_FROM_LOW($dst$$Register));
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5541
  %}
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5542
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5543
  ins_pipe(ialu_reg_mem);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5544
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5545
3177
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5546
// Load Unsigned Short/Char (16 bit UNsigned) with mask 0xFF into Long Register
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5547
instruct loadUS2L_immI_255(eRegL dst, memory mem, immI_255 mask, eFlagsReg cr) %{
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5548
  match(Set dst (ConvI2L (AndI (LoadUS mem) mask)));
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5549
  effect(KILL cr);
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5550
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5551
  format %{ "MOVZX8 $dst.lo,$mem\t# ushort/char & 0xFF -> long\n\t"
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5552
            "XOR    $dst.hi,$dst.hi" %}
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5553
  ins_encode %{
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5554
    Register Rdst = $dst$$Register;
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5555
    __ movzbl(Rdst, $mem$$Address);
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5556
    __ xorl(HIGH_FROM_LOW(Rdst), HIGH_FROM_LOW(Rdst));
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5557
  %}
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5558
  ins_pipe(ialu_reg_mem);
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5559
%}
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5560
31047
50c0dc40661c 8001622: loadUB2L_immI8 & loadUS2L_immI16 rules don't match some 8-bit/16-bit masks
vlivanov
parents: 30624
diff changeset
  5561
// Load Unsigned Short/Char (16 bit UNsigned) with a 32-bit mask into Long Register
50c0dc40661c 8001622: loadUB2L_immI8 & loadUS2L_immI16 rules don't match some 8-bit/16-bit masks
vlivanov
parents: 30624
diff changeset
  5562
instruct loadUS2L_immI(eRegL dst, memory mem, immI mask, eFlagsReg cr) %{
3177
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5563
  match(Set dst (ConvI2L (AndI (LoadUS mem) mask)));
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5564
  effect(KILL cr);
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5565
31047
50c0dc40661c 8001622: loadUB2L_immI8 & loadUS2L_immI16 rules don't match some 8-bit/16-bit masks
vlivanov
parents: 30624
diff changeset
  5566
  format %{ "MOVZX  $dst.lo, $mem\t# ushort/char & 32-bit mask -> long\n\t"
3177
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5567
            "XOR    $dst.hi,$dst.hi\n\t"
31047
50c0dc40661c 8001622: loadUB2L_immI8 & loadUS2L_immI16 rules don't match some 8-bit/16-bit masks
vlivanov
parents: 30624
diff changeset
  5568
            "AND    $dst.lo,right_n_bits($mask, 16)" %}
3177
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5569
  ins_encode %{
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5570
    Register Rdst = $dst$$Register;
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5571
    __ movzwl(Rdst, $mem$$Address);
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5572
    __ xorl(HIGH_FROM_LOW(Rdst), HIGH_FROM_LOW(Rdst));
31047
50c0dc40661c 8001622: loadUB2L_immI8 & loadUS2L_immI16 rules don't match some 8-bit/16-bit masks
vlivanov
parents: 30624
diff changeset
  5573
    __ andl(Rdst, $mask$$constant & right_n_bits(16));
3177
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5574
  %}
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5575
  ins_pipe(ialu_reg_mem);
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5576
%}
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5577
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5578
// Load Integer
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  5579
instruct loadI(rRegI dst, memory mem) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5580
  match(Set dst (LoadI mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5581
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5582
  ins_cost(125);
2150
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5583
  format %{ "MOV    $dst,$mem\t# int" %}
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5584
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5585
  ins_encode %{
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5586
    __ movl($dst$$Register, $mem$$Address);
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5587
  %}
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5588
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5589
  ins_pipe(ialu_reg_mem);
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5590
%}
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5591
2872
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  5592
// Load Integer (32 bit signed) to Byte (8 bit signed)
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  5593
instruct loadI2B(rRegI dst, memory mem, immI_24 twentyfour) %{
2872
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  5594
  match(Set dst (RShiftI (LShiftI (LoadI mem) twentyfour) twentyfour));
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  5595
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  5596
  ins_cost(125);
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  5597
  format %{ "MOVSX  $dst, $mem\t# int -> byte" %}
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  5598
  ins_encode %{
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  5599
    __ movsbl($dst$$Register, $mem$$Address);
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  5600
  %}
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  5601
  ins_pipe(ialu_reg_mem);
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  5602
%}
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  5603
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  5604
// Load Integer (32 bit signed) to Unsigned Byte (8 bit UNsigned)
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  5605
instruct loadI2UB(rRegI dst, memory mem, immI_255 mask) %{
2872
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  5606
  match(Set dst (AndI (LoadI mem) mask));
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  5607
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  5608
  ins_cost(125);
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  5609
  format %{ "MOVZX  $dst, $mem\t# int -> ubyte" %}
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  5610
  ins_encode %{
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  5611
    __ movzbl($dst$$Register, $mem$$Address);
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  5612
  %}
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  5613
  ins_pipe(ialu_reg_mem);
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  5614
%}
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  5615
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  5616
// Load Integer (32 bit signed) to Short (16 bit signed)
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  5617
instruct loadI2S(rRegI dst, memory mem, immI_16 sixteen) %{
2872
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  5618
  match(Set dst (RShiftI (LShiftI (LoadI mem) sixteen) sixteen));
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  5619
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  5620
  ins_cost(125);
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  5621
  format %{ "MOVSX  $dst, $mem\t# int -> short" %}
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  5622
  ins_encode %{
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  5623
    __ movswl($dst$$Register, $mem$$Address);
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  5624
  %}
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  5625
  ins_pipe(ialu_reg_mem);
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  5626
%}
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  5627
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  5628
// Load Integer (32 bit signed) to Unsigned Short/Char (16 bit UNsigned)
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  5629
instruct loadI2US(rRegI dst, memory mem, immI_65535 mask) %{
2872
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  5630
  match(Set dst (AndI (LoadI mem) mask));
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  5631
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  5632
  ins_cost(125);
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  5633
  format %{ "MOVZX  $dst, $mem\t# int -> ushort/char" %}
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  5634
  ins_encode %{
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  5635
    __ movzwl($dst$$Register, $mem$$Address);
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  5636
  %}
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  5637
  ins_pipe(ialu_reg_mem);
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  5638
%}
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  5639
2150
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5640
// Load Integer into Long Register
3177
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5641
instruct loadI2L(eRegL dst, memory mem, eFlagsReg cr) %{
2150
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5642
  match(Set dst (ConvI2L (LoadI mem)));
3177
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5643
  effect(KILL cr);
2150
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5644
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5645
  ins_cost(375);
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5646
  format %{ "MOV    $dst.lo,$mem\t# int -> long\n\t"
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5647
            "MOV    $dst.hi,$dst.lo\n\t"
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5648
            "SAR    $dst.hi,31" %}
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5649
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5650
  ins_encode %{
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5651
    __ movl($dst$$Register, $mem$$Address);
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5652
    __ movl(HIGH_FROM_LOW($dst$$Register), $dst$$Register); // This is always a different register.
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5653
    __ sarl(HIGH_FROM_LOW($dst$$Register), 31);
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5654
  %}
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5655
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5656
  ins_pipe(ialu_reg_mem);
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5657
%}
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5658
3177
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5659
// Load Integer with mask 0xFF into Long Register
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5660
instruct loadI2L_immI_255(eRegL dst, memory mem, immI_255 mask, eFlagsReg cr) %{
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5661
  match(Set dst (ConvI2L (AndI (LoadI mem) mask)));
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5662
  effect(KILL cr);
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5663
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5664
  format %{ "MOVZX8 $dst.lo,$mem\t# int & 0xFF -> long\n\t"
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5665
            "XOR    $dst.hi,$dst.hi" %}
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5666
  ins_encode %{
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5667
    Register Rdst = $dst$$Register;
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5668
    __ movzbl(Rdst, $mem$$Address);
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5669
    __ xorl(HIGH_FROM_LOW(Rdst), HIGH_FROM_LOW(Rdst));
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5670
  %}
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5671
  ins_pipe(ialu_reg_mem);
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5672
%}
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5673
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5674
// Load Integer with mask 0xFFFF into Long Register
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5675
instruct loadI2L_immI_65535(eRegL dst, memory mem, immI_65535 mask, eFlagsReg cr) %{
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5676
  match(Set dst (ConvI2L (AndI (LoadI mem) mask)));
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5677
  effect(KILL cr);
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5678
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5679
  format %{ "MOVZX  $dst.lo,$mem\t# int & 0xFFFF -> long\n\t"
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5680
            "XOR    $dst.hi,$dst.hi" %}
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5681
  ins_encode %{
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5682
    Register Rdst = $dst$$Register;
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5683
    __ movzwl(Rdst, $mem$$Address);
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5684
    __ xorl(HIGH_FROM_LOW(Rdst), HIGH_FROM_LOW(Rdst));
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5685
  %}
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5686
  ins_pipe(ialu_reg_mem);
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5687
%}
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5688
22513
dc47bc8ecb75 8031743: C2: loadI2L_immI broken for negative memory values
iveresov
parents: 21105
diff changeset
  5689
// Load Integer with 31-bit mask into Long Register
dc47bc8ecb75 8031743: C2: loadI2L_immI broken for negative memory values
iveresov
parents: 21105
diff changeset
  5690
instruct loadI2L_immU31(eRegL dst, memory mem, immU31 mask, eFlagsReg cr) %{
3177
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5691
  match(Set dst (ConvI2L (AndI (LoadI mem) mask)));
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5692
  effect(KILL cr);
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5693
22513
dc47bc8ecb75 8031743: C2: loadI2L_immI broken for negative memory values
iveresov
parents: 21105
diff changeset
  5694
  format %{ "MOV    $dst.lo,$mem\t# int & 31-bit mask -> long\n\t"
3177
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5695
            "XOR    $dst.hi,$dst.hi\n\t"
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5696
            "AND    $dst.lo,$mask" %}
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5697
  ins_encode %{
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5698
    Register Rdst = $dst$$Register;
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5699
    __ movl(Rdst, $mem$$Address);
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5700
    __ xorl(HIGH_FROM_LOW(Rdst), HIGH_FROM_LOW(Rdst));
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5701
    __ andl(Rdst, $mask$$constant);
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5702
  %}
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5703
  ins_pipe(ialu_reg_mem);
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5704
%}
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5705
2150
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5706
// Load Unsigned Integer into Long Register
13970
11a9630698a6 7199654: Remove LoadUI2LNode
vlivanov
parents: 13969
diff changeset
  5707
instruct loadUI2L(eRegL dst, memory mem, immL_32bits mask, eFlagsReg cr) %{
11a9630698a6 7199654: Remove LoadUI2LNode
vlivanov
parents: 13969
diff changeset
  5708
  match(Set dst (AndL (ConvI2L (LoadI mem)) mask));
3177
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  5709
  effect(KILL cr);
2150
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5710
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5711
  ins_cost(250);
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5712
  format %{ "MOV    $dst.lo,$mem\t# uint -> long\n\t"
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5713
            "XOR    $dst.hi,$dst.hi" %}
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5714
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5715
  ins_encode %{
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5716
    __ movl($dst$$Register, $mem$$Address);
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5717
    __ xorl(HIGH_FROM_LOW($dst$$Register), HIGH_FROM_LOW($dst$$Register));
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5718
  %}
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5719
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5720
  ins_pipe(ialu_reg_mem);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5721
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5722
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5723
// Load Long.  Cannot clobber address while loading, so restrict address
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5724
// register to ESI
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5725
instruct loadL(eRegL dst, load_long_memory mem) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5726
  predicate(!((LoadLNode*)n)->require_atomic_access());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5727
  match(Set dst (LoadL mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5728
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5729
  ins_cost(250);
2150
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5730
  format %{ "MOV    $dst.lo,$mem\t# long\n\t"
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5731
            "MOV    $dst.hi,$mem+4" %}
2150
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5732
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5733
  ins_encode %{
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13485
diff changeset
  5734
    Address Amemlo = Address::make_raw($mem$$base, $mem$$index, $mem$$scale, $mem$$disp, relocInfo::none);
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13485
diff changeset
  5735
    Address Amemhi = Address::make_raw($mem$$base, $mem$$index, $mem$$scale, $mem$$disp + 4, relocInfo::none);
2150
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5736
    __ movl($dst$$Register, Amemlo);
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5737
    __ movl(HIGH_FROM_LOW($dst$$Register), Amemhi);
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5738
  %}
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5739
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5740
  ins_pipe(ialu_reg_long_mem);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5741
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5742
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5743
// Volatile Load Long.  Must be atomic, so do 64-bit FILD
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5744
// then store it down to the stack and reload on the int
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5745
// side.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5746
instruct loadL_volatile(stackSlotL dst, memory mem) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5747
  predicate(UseSSE<=1 && ((LoadLNode*)n)->require_atomic_access());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5748
  match(Set dst (LoadL mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5749
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5750
  ins_cost(200);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5751
  format %{ "FILD   $mem\t# Atomic volatile long load\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5752
            "FISTp  $dst" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5753
  ins_encode(enc_loadL_volatile(mem,dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5754
  ins_pipe( fpu_reg_mem );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5755
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5756
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  5757
instruct loadLX_volatile(stackSlotL dst, memory mem, regD tmp) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5758
  predicate(UseSSE>=2 && ((LoadLNode*)n)->require_atomic_access());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5759
  match(Set dst (LoadL mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5760
  effect(TEMP tmp);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5761
  ins_cost(180);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5762
  format %{ "MOVSD  $tmp,$mem\t# Atomic volatile long load\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5763
            "MOVSD  $dst,$tmp" %}
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  5764
  ins_encode %{
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  5765
    __ movdbl($tmp$$XMMRegister, $mem$$Address);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  5766
    __ movdbl(Address(rsp, $dst$$disp), $tmp$$XMMRegister);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  5767
  %}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5768
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5769
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5770
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  5771
instruct loadLX_reg_volatile(eRegL dst, memory mem, regD tmp) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5772
  predicate(UseSSE>=2 && ((LoadLNode*)n)->require_atomic_access());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5773
  match(Set dst (LoadL mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5774
  effect(TEMP tmp);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5775
  ins_cost(160);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5776
  format %{ "MOVSD  $tmp,$mem\t# Atomic volatile long load\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5777
            "MOVD   $dst.lo,$tmp\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5778
            "PSRLQ  $tmp,32\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5779
            "MOVD   $dst.hi,$tmp" %}
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  5780
  ins_encode %{
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  5781
    __ movdbl($tmp$$XMMRegister, $mem$$Address);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  5782
    __ movdl($dst$$Register, $tmp$$XMMRegister);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  5783
    __ psrlq($tmp$$XMMRegister, 32);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  5784
    __ movdl(HIGH_FROM_LOW($dst$$Register), $tmp$$XMMRegister);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  5785
  %}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5786
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5787
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5788
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5789
// Load Range
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  5790
instruct loadRange(rRegI dst, memory mem) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5791
  match(Set dst (LoadRange mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5792
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5793
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5794
  format %{ "MOV    $dst,$mem" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5795
  opcode(0x8B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5796
  ins_encode( OpcP, RegMem(dst,mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5797
  ins_pipe( ialu_reg_mem );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5798
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5799
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5800
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5801
// Load Pointer
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5802
instruct loadP(eRegP dst, memory mem) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5803
  match(Set dst (LoadP mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5804
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5805
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5806
  format %{ "MOV    $dst,$mem" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5807
  opcode(0x8B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5808
  ins_encode( OpcP, RegMem(dst,mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5809
  ins_pipe( ialu_reg_mem );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5810
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5811
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5812
// Load Klass Pointer
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5813
instruct loadKlass(eRegP dst, memory mem) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5814
  match(Set dst (LoadKlass mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5815
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5816
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5817
  format %{ "MOV    $dst,$mem" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5818
  opcode(0x8B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5819
  ins_encode( OpcP, RegMem(dst,mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5820
  ins_pipe( ialu_reg_mem );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5821
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5822
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5823
// Load Double
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  5824
instruct loadDPR(regDPR dst, memory mem) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5825
  predicate(UseSSE<=1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5826
  match(Set dst (LoadD mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5827
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5828
  ins_cost(150);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5829
  format %{ "FLD_D  ST,$mem\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5830
            "FSTP   $dst" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5831
  opcode(0xDD);               /* DD /0 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5832
  ins_encode( OpcP, RMopc_Mem(0x00,mem),
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  5833
              Pop_Reg_DPR(dst) );
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5834
  ins_pipe( fpu_reg_mem );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5835
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5836
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5837
// Load Double to XMM
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  5838
instruct loadD(regD dst, memory mem) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5839
  predicate(UseSSE>=2 && UseXmmLoadAndClearUpper);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5840
  match(Set dst (LoadD mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5841
  ins_cost(145);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5842
  format %{ "MOVSD  $dst,$mem" %}
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  5843
  ins_encode %{
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  5844
    __ movdbl ($dst$$XMMRegister, $mem$$Address);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  5845
  %}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5846
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5847
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5848
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  5849
instruct loadD_partial(regD dst, memory mem) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5850
  predicate(UseSSE>=2 && !UseXmmLoadAndClearUpper);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5851
  match(Set dst (LoadD mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5852
  ins_cost(145);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5853
  format %{ "MOVLPD $dst,$mem" %}
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  5854
  ins_encode %{
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  5855
    __ movdbl ($dst$$XMMRegister, $mem$$Address);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  5856
  %}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5857
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5858
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5859
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5860
// Load to XMM register (single-precision floating point)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5861
// MOVSS instruction
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  5862
instruct loadF(regF dst, memory mem) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5863
  predicate(UseSSE>=1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5864
  match(Set dst (LoadF mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5865
  ins_cost(145);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5866
  format %{ "MOVSS  $dst,$mem" %}
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  5867
  ins_encode %{
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  5868
    __ movflt ($dst$$XMMRegister, $mem$$Address);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  5869
  %}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5870
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5871
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5872
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5873
// Load Float
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  5874
instruct loadFPR(regFPR dst, memory mem) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5875
  predicate(UseSSE==0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5876
  match(Set dst (LoadF mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5877
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5878
  ins_cost(150);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5879
  format %{ "FLD_S  ST,$mem\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5880
            "FSTP   $dst" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5881
  opcode(0xD9);               /* D9 /0 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5882
  ins_encode( OpcP, RMopc_Mem(0x00,mem),
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  5883
              Pop_Reg_FPR(dst) );
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5884
  ins_pipe( fpu_reg_mem );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5885
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5886
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5887
// Load Effective Address
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5888
instruct leaP8(eRegP dst, indOffset8 mem) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5889
  match(Set dst mem);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5890
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5891
  ins_cost(110);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5892
  format %{ "LEA    $dst,$mem" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5893
  opcode(0x8D);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5894
  ins_encode( OpcP, RegMem(dst,mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5895
  ins_pipe( ialu_reg_reg_fat );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5896
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5897
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5898
instruct leaP32(eRegP dst, indOffset32 mem) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5899
  match(Set dst mem);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5900
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5901
  ins_cost(110);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5902
  format %{ "LEA    $dst,$mem" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5903
  opcode(0x8D);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5904
  ins_encode( OpcP, RegMem(dst,mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5905
  ins_pipe( ialu_reg_reg_fat );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5906
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5907
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5908
instruct leaPIdxOff(eRegP dst, indIndexOffset mem) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5909
  match(Set dst mem);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5910
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5911
  ins_cost(110);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5912
  format %{ "LEA    $dst,$mem" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5913
  opcode(0x8D);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5914
  ins_encode( OpcP, RegMem(dst,mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5915
  ins_pipe( ialu_reg_reg_fat );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5916
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5917
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5918
instruct leaPIdxScale(eRegP dst, indIndexScale mem) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5919
  match(Set dst mem);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5920
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5921
  ins_cost(110);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5922
  format %{ "LEA    $dst,$mem" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5923
  opcode(0x8D);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5924
  ins_encode( OpcP, RegMem(dst,mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5925
  ins_pipe( ialu_reg_reg_fat );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5926
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5927
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5928
instruct leaPIdxScaleOff(eRegP dst, indIndexScaleOffset mem) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5929
  match(Set dst mem);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5930
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5931
  ins_cost(110);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5932
  format %{ "LEA    $dst,$mem" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5933
  opcode(0x8D);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5934
  ins_encode( OpcP, RegMem(dst,mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5935
  ins_pipe( ialu_reg_reg_fat );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5936
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5937
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5938
// Load Constant
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  5939
instruct loadConI(rRegI dst, immI src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5940
  match(Set dst src);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5941
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5942
  format %{ "MOV    $dst,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5943
  ins_encode( LdImmI(dst, src) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5944
  ins_pipe( ialu_reg_fat );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5945
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5946
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5947
// Load Constant zero
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  5948
instruct loadConI0(rRegI dst, immI0 src, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5949
  match(Set dst src);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5950
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5951
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5952
  ins_cost(50);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5953
  format %{ "XOR    $dst,$dst" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5954
  opcode(0x33);  /* + rd */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5955
  ins_encode( OpcP, RegReg( dst, dst ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5956
  ins_pipe( ialu_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5957
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5958
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5959
instruct loadConP(eRegP dst, immP src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5960
  match(Set dst src);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5961
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5962
  format %{ "MOV    $dst,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5963
  opcode(0xB8);  /* + rd */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5964
  ins_encode( LdImmP(dst, src) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5965
  ins_pipe( ialu_reg_fat );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5966
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5967
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5968
instruct loadConL(eRegL dst, immL src, eFlagsReg cr) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5969
  match(Set dst src);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5970
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5971
  ins_cost(200);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5972
  format %{ "MOV    $dst.lo,$src.lo\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5973
            "MOV    $dst.hi,$src.hi" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5974
  opcode(0xB8);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5975
  ins_encode( LdImmL_Lo(dst, src), LdImmL_Hi(dst, src) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5976
  ins_pipe( ialu_reg_long_fat );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5977
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5978
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5979
instruct loadConL0(eRegL dst, immL0 src, eFlagsReg cr) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5980
  match(Set dst src);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5981
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5982
  ins_cost(150);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5983
  format %{ "XOR    $dst.lo,$dst.lo\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5984
            "XOR    $dst.hi,$dst.hi" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5985
  opcode(0x33,0x33);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5986
  ins_encode( RegReg_Lo(dst,dst), RegReg_Hi(dst, dst) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5987
  ins_pipe( ialu_reg_long );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5988
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5989
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  5990
// The instruction usage is guarded by predicate in operand immFPR().
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  5991
instruct loadConFPR(regFPR dst, immFPR con) %{
7433
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  5992
  match(Set dst con);
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  5993
  ins_cost(125);
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  5994
  format %{ "FLD_S  ST,[$constantaddress]\t# load from constant table: float=$con\n\t"
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  5995
            "FSTP   $dst" %}
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  5996
  ins_encode %{
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  5997
    __ fld_s($constantaddress($con));
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  5998
    __ fstp_d($dst$$reg);
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  5999
  %}
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  6000
  ins_pipe(fpu_reg_con);
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  6001
%}
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  6002
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  6003
// The instruction usage is guarded by predicate in operand immFPR0().
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  6004
instruct loadConFPR0(regFPR dst, immFPR0 con) %{
7433
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  6005
  match(Set dst con);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6006
  ins_cost(125);
7433
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  6007
  format %{ "FLDZ   ST\n\t"
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6008
            "FSTP   $dst" %}
7433
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  6009
  ins_encode %{
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  6010
    __ fldz();
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  6011
    __ fstp_d($dst$$reg);
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  6012
  %}
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  6013
  ins_pipe(fpu_reg_con);
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  6014
%}
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  6015
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  6016
// The instruction usage is guarded by predicate in operand immFPR1().
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  6017
instruct loadConFPR1(regFPR dst, immFPR1 con) %{
7433
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  6018
  match(Set dst con);
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  6019
  ins_cost(125);
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  6020
  format %{ "FLD1   ST\n\t"
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  6021
            "FSTP   $dst" %}
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  6022
  ins_encode %{
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  6023
    __ fld1();
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  6024
    __ fstp_d($dst$$reg);
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  6025
  %}
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  6026
  ins_pipe(fpu_reg_con);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6027
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6028
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  6029
// The instruction usage is guarded by predicate in operand immF().
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  6030
instruct loadConF(regF dst, immF con) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6031
  match(Set dst con);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6032
  ins_cost(125);
7433
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  6033
  format %{ "MOVSS  $dst,[$constantaddress]\t# load from constant table: float=$con" %}
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  6034
  ins_encode %{
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  6035
    __ movflt($dst$$XMMRegister, $constantaddress($con));
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  6036
  %}
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  6037
  ins_pipe(pipe_slow);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6038
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6039
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  6040
// The instruction usage is guarded by predicate in operand immF0().
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  6041
instruct loadConF0(regF dst, immF0 src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6042
  match(Set dst src);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6043
  ins_cost(100);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6044
  format %{ "XORPS  $dst,$dst\t# float 0.0" %}
7433
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  6045
  ins_encode %{
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  6046
    __ xorps($dst$$XMMRegister, $dst$$XMMRegister);
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  6047
  %}
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  6048
  ins_pipe(pipe_slow);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6049
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6050
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  6051
// The instruction usage is guarded by predicate in operand immDPR().
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  6052
instruct loadConDPR(regDPR dst, immDPR con) %{
7433
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  6053
  match(Set dst con);
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  6054
  ins_cost(125);
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  6055
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  6056
  format %{ "FLD_D  ST,[$constantaddress]\t# load from constant table: double=$con\n\t"
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  6057
            "FSTP   $dst" %}
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  6058
  ins_encode %{
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  6059
    __ fld_d($constantaddress($con));
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  6060
    __ fstp_d($dst$$reg);
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  6061
  %}
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  6062
  ins_pipe(fpu_reg_con);
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  6063
%}
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  6064
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  6065
// The instruction usage is guarded by predicate in operand immDPR0().
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  6066
instruct loadConDPR0(regDPR dst, immDPR0 con) %{
7433
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  6067
  match(Set dst con);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6068
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6069
7433
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  6070
  format %{ "FLDZ   ST\n\t"
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6071
            "FSTP   $dst" %}
7433
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  6072
  ins_encode %{
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  6073
    __ fldz();
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  6074
    __ fstp_d($dst$$reg);
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  6075
  %}
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  6076
  ins_pipe(fpu_reg_con);
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  6077
%}
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  6078
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  6079
// The instruction usage is guarded by predicate in operand immDPR1().
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  6080
instruct loadConDPR1(regDPR dst, immDPR1 con) %{
7433
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  6081
  match(Set dst con);
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  6082
  ins_cost(125);
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  6083
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  6084
  format %{ "FLD1   ST\n\t"
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  6085
            "FSTP   $dst" %}
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  6086
  ins_encode %{
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  6087
    __ fld1();
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  6088
    __ fstp_d($dst$$reg);
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  6089
  %}
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  6090
  ins_pipe(fpu_reg_con);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6091
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6092
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  6093
// The instruction usage is guarded by predicate in operand immD().
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  6094
instruct loadConD(regD dst, immD con) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6095
  match(Set dst con);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6096
  ins_cost(125);
7433
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  6097
  format %{ "MOVSD  $dst,[$constantaddress]\t# load from constant table: double=$con" %}
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  6098
  ins_encode %{
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  6099
    __ movdbl($dst$$XMMRegister, $constantaddress($con));
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  6100
  %}
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  6101
  ins_pipe(pipe_slow);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6102
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6103
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  6104
// The instruction usage is guarded by predicate in operand immD0().
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  6105
instruct loadConD0(regD dst, immD0 src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6106
  match(Set dst src);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6107
  ins_cost(100);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6108
  format %{ "XORPD  $dst,$dst\t# double 0.0" %}
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  6109
  ins_encode %{
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  6110
    __ xorpd ($dst$$XMMRegister, $dst$$XMMRegister);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  6111
  %}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6112
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6113
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6114
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6115
// Load Stack Slot
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  6116
instruct loadSSI(rRegI dst, stackSlotI src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6117
  match(Set dst src);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6118
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6119
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6120
  format %{ "MOV    $dst,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6121
  opcode(0x8B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6122
  ins_encode( OpcP, RegMem(dst,src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6123
  ins_pipe( ialu_reg_mem );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6124
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6125
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6126
instruct loadSSL(eRegL dst, stackSlotL src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6127
  match(Set dst src);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6128
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6129
  ins_cost(200);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6130
  format %{ "MOV    $dst,$src.lo\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6131
            "MOV    $dst+4,$src.hi" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6132
  opcode(0x8B, 0x8B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6133
  ins_encode( OpcP, RegMem( dst, src ), OpcS, RegMem_Hi( dst, src ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6134
  ins_pipe( ialu_mem_long_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6135
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6136
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6137
// Load Stack Slot
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6138
instruct loadSSP(eRegP dst, stackSlotP src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6139
  match(Set dst src);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6140
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6141
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6142
  format %{ "MOV    $dst,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6143
  opcode(0x8B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6144
  ins_encode( OpcP, RegMem(dst,src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6145
  ins_pipe( ialu_reg_mem );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6146
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6147
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6148
// Load Stack Slot
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  6149
instruct loadSSF(regFPR dst, stackSlotF src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6150
  match(Set dst src);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6151
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6152
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6153
  format %{ "FLD_S  $src\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6154
            "FSTP   $dst" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6155
  opcode(0xD9);               /* D9 /0, FLD m32real */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6156
  ins_encode( OpcP, RMopc_Mem_no_oop(0x00,src),
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  6157
              Pop_Reg_FPR(dst) );
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6158
  ins_pipe( fpu_reg_mem );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6159
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6160
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6161
// Load Stack Slot
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  6162
instruct loadSSD(regDPR dst, stackSlotD src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6163
  match(Set dst src);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6164
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6165
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6166
  format %{ "FLD_D  $src\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6167
            "FSTP   $dst" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6168
  opcode(0xDD);               /* DD /0, FLD m64real */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6169
  ins_encode( OpcP, RMopc_Mem_no_oop(0x00,src),
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  6170
              Pop_Reg_DPR(dst) );
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6171
  ins_pipe( fpu_reg_mem );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6172
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6173
28954
7dda6c26cc98 8068977: Remove unused sun.misc.Unsafe prefetch intrinsic support
psandoz
parents: 27677
diff changeset
  6174
// Prefetch instructions for allocation.
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6175
// Must be safe to execute with invalid address (cannot fault).
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6176
10267
8bdeec886dc4 7079329: Adjust allocation prefetching for T4
kvn
parents: 10264
diff changeset
  6177
instruct prefetchAlloc0( memory mem ) %{
8bdeec886dc4 7079329: Adjust allocation prefetching for T4
kvn
parents: 10264
diff changeset
  6178
  predicate(UseSSE==0 && AllocatePrefetchInstr!=3);
8bdeec886dc4 7079329: Adjust allocation prefetching for T4
kvn
parents: 10264
diff changeset
  6179
  match(PrefetchAllocation mem);
8bdeec886dc4 7079329: Adjust allocation prefetching for T4
kvn
parents: 10264
diff changeset
  6180
  ins_cost(0);
8bdeec886dc4 7079329: Adjust allocation prefetching for T4
kvn
parents: 10264
diff changeset
  6181
  size(0);
8bdeec886dc4 7079329: Adjust allocation prefetching for T4
kvn
parents: 10264
diff changeset
  6182
  format %{ "Prefetch allocation (non-SSE is empty encoding)" %}
8bdeec886dc4 7079329: Adjust allocation prefetching for T4
kvn
parents: 10264
diff changeset
  6183
  ins_encode();
8bdeec886dc4 7079329: Adjust allocation prefetching for T4
kvn
parents: 10264
diff changeset
  6184
  ins_pipe(empty);
8bdeec886dc4 7079329: Adjust allocation prefetching for T4
kvn
parents: 10264
diff changeset
  6185
%}
8bdeec886dc4 7079329: Adjust allocation prefetching for T4
kvn
parents: 10264
diff changeset
  6186
8bdeec886dc4 7079329: Adjust allocation prefetching for T4
kvn
parents: 10264
diff changeset
  6187
instruct prefetchAlloc( memory mem ) %{
8bdeec886dc4 7079329: Adjust allocation prefetching for T4
kvn
parents: 10264
diff changeset
  6188
  predicate(AllocatePrefetchInstr==3);
8bdeec886dc4 7079329: Adjust allocation prefetching for T4
kvn
parents: 10264
diff changeset
  6189
  match( PrefetchAllocation mem );
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6190
  ins_cost(100);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6191
10267
8bdeec886dc4 7079329: Adjust allocation prefetching for T4
kvn
parents: 10264
diff changeset
  6192
  format %{ "PREFETCHW $mem\t! Prefetch allocation into L1 cache and mark modified" %}
8bdeec886dc4 7079329: Adjust allocation prefetching for T4
kvn
parents: 10264
diff changeset
  6193
  ins_encode %{
8bdeec886dc4 7079329: Adjust allocation prefetching for T4
kvn
parents: 10264
diff changeset
  6194
    __ prefetchw($mem$$Address);
8bdeec886dc4 7079329: Adjust allocation prefetching for T4
kvn
parents: 10264
diff changeset
  6195
  %}
8bdeec886dc4 7079329: Adjust allocation prefetching for T4
kvn
parents: 10264
diff changeset
  6196
  ins_pipe(ialu_mem);
8bdeec886dc4 7079329: Adjust allocation prefetching for T4
kvn
parents: 10264
diff changeset
  6197
%}
8bdeec886dc4 7079329: Adjust allocation prefetching for T4
kvn
parents: 10264
diff changeset
  6198
8bdeec886dc4 7079329: Adjust allocation prefetching for T4
kvn
parents: 10264
diff changeset
  6199
instruct prefetchAllocNTA( memory mem ) %{
8bdeec886dc4 7079329: Adjust allocation prefetching for T4
kvn
parents: 10264
diff changeset
  6200
  predicate(UseSSE>=1 && AllocatePrefetchInstr==0);
8bdeec886dc4 7079329: Adjust allocation prefetching for T4
kvn
parents: 10264
diff changeset
  6201
  match(PrefetchAllocation mem);
8bdeec886dc4 7079329: Adjust allocation prefetching for T4
kvn
parents: 10264
diff changeset
  6202
  ins_cost(100);
8bdeec886dc4 7079329: Adjust allocation prefetching for T4
kvn
parents: 10264
diff changeset
  6203
8bdeec886dc4 7079329: Adjust allocation prefetching for T4
kvn
parents: 10264
diff changeset
  6204
  format %{ "PREFETCHNTA $mem\t! Prefetch allocation into non-temporal cache for write" %}
8bdeec886dc4 7079329: Adjust allocation prefetching for T4
kvn
parents: 10264
diff changeset
  6205
  ins_encode %{
8bdeec886dc4 7079329: Adjust allocation prefetching for T4
kvn
parents: 10264
diff changeset
  6206
    __ prefetchnta($mem$$Address);
8bdeec886dc4 7079329: Adjust allocation prefetching for T4
kvn
parents: 10264
diff changeset
  6207
  %}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6208
  ins_pipe(ialu_mem);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6209
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6210
10267
8bdeec886dc4 7079329: Adjust allocation prefetching for T4
kvn
parents: 10264
diff changeset
  6211
instruct prefetchAllocT0( memory mem ) %{
8bdeec886dc4 7079329: Adjust allocation prefetching for T4
kvn
parents: 10264
diff changeset
  6212
  predicate(UseSSE>=1 && AllocatePrefetchInstr==1);
8bdeec886dc4 7079329: Adjust allocation prefetching for T4
kvn
parents: 10264
diff changeset
  6213
  match(PrefetchAllocation mem);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6214
  ins_cost(100);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6215
10267
8bdeec886dc4 7079329: Adjust allocation prefetching for T4
kvn
parents: 10264
diff changeset
  6216
  format %{ "PREFETCHT0 $mem\t! Prefetch allocation into L1 and L2 caches for write" %}
8bdeec886dc4 7079329: Adjust allocation prefetching for T4
kvn
parents: 10264
diff changeset
  6217
  ins_encode %{
8bdeec886dc4 7079329: Adjust allocation prefetching for T4
kvn
parents: 10264
diff changeset
  6218
    __ prefetcht0($mem$$Address);
8bdeec886dc4 7079329: Adjust allocation prefetching for T4
kvn
parents: 10264
diff changeset
  6219
  %}
8bdeec886dc4 7079329: Adjust allocation prefetching for T4
kvn
parents: 10264
diff changeset
  6220
  ins_pipe(ialu_mem);
8bdeec886dc4 7079329: Adjust allocation prefetching for T4
kvn
parents: 10264
diff changeset
  6221
%}
8bdeec886dc4 7079329: Adjust allocation prefetching for T4
kvn
parents: 10264
diff changeset
  6222
8bdeec886dc4 7079329: Adjust allocation prefetching for T4
kvn
parents: 10264
diff changeset
  6223
instruct prefetchAllocT2( memory mem ) %{
8bdeec886dc4 7079329: Adjust allocation prefetching for T4
kvn
parents: 10264
diff changeset
  6224
  predicate(UseSSE>=1 && AllocatePrefetchInstr==2);
8bdeec886dc4 7079329: Adjust allocation prefetching for T4
kvn
parents: 10264
diff changeset
  6225
  match(PrefetchAllocation mem);
8bdeec886dc4 7079329: Adjust allocation prefetching for T4
kvn
parents: 10264
diff changeset
  6226
  ins_cost(100);
8bdeec886dc4 7079329: Adjust allocation prefetching for T4
kvn
parents: 10264
diff changeset
  6227
8bdeec886dc4 7079329: Adjust allocation prefetching for T4
kvn
parents: 10264
diff changeset
  6228
  format %{ "PREFETCHT2 $mem\t! Prefetch allocation into L2 cache for write" %}
8bdeec886dc4 7079329: Adjust allocation prefetching for T4
kvn
parents: 10264
diff changeset
  6229
  ins_encode %{
8bdeec886dc4 7079329: Adjust allocation prefetching for T4
kvn
parents: 10264
diff changeset
  6230
    __ prefetcht2($mem$$Address);
8bdeec886dc4 7079329: Adjust allocation prefetching for T4
kvn
parents: 10264
diff changeset
  6231
  %}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6232
  ins_pipe(ialu_mem);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6233
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6234
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6235
//----------Store Instructions-------------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6236
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6237
// Store Byte
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6238
instruct storeB(memory mem, xRegI src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6239
  match(Set mem (StoreB mem src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6240
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6241
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6242
  format %{ "MOV8   $mem,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6243
  opcode(0x88);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6244
  ins_encode( OpcP, RegMem( src, mem ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6245
  ins_pipe( ialu_mem_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6246
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6247
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6248
// Store Char/Short
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  6249
instruct storeC(memory mem, rRegI src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6250
  match(Set mem (StoreC mem src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6251
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6252
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6253
  format %{ "MOV16  $mem,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6254
  opcode(0x89, 0x66);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6255
  ins_encode( OpcS, OpcP, RegMem( src, mem ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6256
  ins_pipe( ialu_mem_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6257
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6258
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6259
// Store Integer
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  6260
instruct storeI(memory mem, rRegI src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6261
  match(Set mem (StoreI mem src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6262
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6263
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6264
  format %{ "MOV    $mem,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6265
  opcode(0x89);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6266
  ins_encode( OpcP, RegMem( src, mem ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6267
  ins_pipe( ialu_mem_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6268
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6269
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6270
// Store Long
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6271
instruct storeL(long_memory mem, eRegL src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6272
  predicate(!((StoreLNode*)n)->require_atomic_access());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6273
  match(Set mem (StoreL mem src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6274
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6275
  ins_cost(200);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6276
  format %{ "MOV    $mem,$src.lo\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6277
            "MOV    $mem+4,$src.hi" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6278
  opcode(0x89, 0x89);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6279
  ins_encode( OpcP, RegMem( src, mem ), OpcS, RegMem_Hi( src, mem ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6280
  ins_pipe( ialu_mem_long_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6281
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6282
3177
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6283
// Store Long to Integer
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6284
instruct storeL2I(memory mem, eRegL src) %{
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6285
  match(Set mem (StoreI mem (ConvL2I src)));
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6286
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6287
  format %{ "MOV    $mem,$src.lo\t# long -> int" %}
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6288
  ins_encode %{
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6289
    __ movl($mem$$Address, $src$$Register);
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6290
  %}
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6291
  ins_pipe(ialu_mem_reg);
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6292
%}
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6293
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6294
// Volatile Store Long.  Must be atomic, so move it into
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6295
// the FP TOS and then do a 64-bit FIST.  Has to probe the
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6296
// target address before the store (for null-ptr checks)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6297
// so the memory operand is used twice in the encoding.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6298
instruct storeL_volatile(memory mem, stackSlotL src, eFlagsReg cr ) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6299
  predicate(UseSSE<=1 && ((StoreLNode*)n)->require_atomic_access());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6300
  match(Set mem (StoreL mem src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6301
  effect( KILL cr );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6302
  ins_cost(400);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6303
  format %{ "CMP    $mem,EAX\t# Probe address for implicit null check\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6304
            "FILD   $src\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6305
            "FISTp  $mem\t # 64-bit atomic volatile long store" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6306
  opcode(0x3B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6307
  ins_encode( OpcP, RegMem( EAX, mem ), enc_storeL_volatile(mem,src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6308
  ins_pipe( fpu_reg_mem );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6309
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6310
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  6311
instruct storeLX_volatile(memory mem, stackSlotL src, regD tmp, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6312
  predicate(UseSSE>=2 && ((StoreLNode*)n)->require_atomic_access());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6313
  match(Set mem (StoreL mem src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6314
  effect( TEMP tmp, KILL cr );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6315
  ins_cost(380);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6316
  format %{ "CMP    $mem,EAX\t# Probe address for implicit null check\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6317
            "MOVSD  $tmp,$src\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6318
            "MOVSD  $mem,$tmp\t # 64-bit atomic volatile long store" %}
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  6319
  ins_encode %{
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  6320
    __ cmpl(rax, $mem$$Address);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  6321
    __ movdbl($tmp$$XMMRegister, Address(rsp, $src$$disp));
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  6322
    __ movdbl($mem$$Address, $tmp$$XMMRegister);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  6323
  %}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6324
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6325
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6326
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  6327
instruct storeLX_reg_volatile(memory mem, eRegL src, regD tmp2, regD tmp, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6328
  predicate(UseSSE>=2 && ((StoreLNode*)n)->require_atomic_access());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6329
  match(Set mem (StoreL mem src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6330
  effect( TEMP tmp2 , TEMP tmp, KILL cr );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6331
  ins_cost(360);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6332
  format %{ "CMP    $mem,EAX\t# Probe address for implicit null check\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6333
            "MOVD   $tmp,$src.lo\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6334
            "MOVD   $tmp2,$src.hi\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6335
            "PUNPCKLDQ $tmp,$tmp2\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6336
            "MOVSD  $mem,$tmp\t # 64-bit atomic volatile long store" %}
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  6337
  ins_encode %{
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  6338
    __ cmpl(rax, $mem$$Address);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  6339
    __ movdl($tmp$$XMMRegister, $src$$Register);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  6340
    __ movdl($tmp2$$XMMRegister, HIGH_FROM_LOW($src$$Register));
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  6341
    __ punpckldq($tmp$$XMMRegister, $tmp2$$XMMRegister);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  6342
    __ movdbl($mem$$Address, $tmp$$XMMRegister);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  6343
  %}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6344
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6345
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6346
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6347
// Store Pointer; for storing unknown oops and raw pointers
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6348
instruct storeP(memory mem, anyRegP src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6349
  match(Set mem (StoreP mem src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6350
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6351
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6352
  format %{ "MOV    $mem,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6353
  opcode(0x89);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6354
  ins_encode( OpcP, RegMem( src, mem ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6355
  ins_pipe( ialu_mem_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6356
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6357
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6358
// Store Integer Immediate
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6359
instruct storeImmI(memory mem, immI src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6360
  match(Set mem (StoreI mem src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6361
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6362
  ins_cost(150);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6363
  format %{ "MOV    $mem,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6364
  opcode(0xC7);               /* C7 /0 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6365
  ins_encode( OpcP, RMopc_Mem(0x00,mem),  Con32( src ));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6366
  ins_pipe( ialu_mem_imm );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6367
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6368
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6369
// Store Short/Char Immediate
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6370
instruct storeImmI16(memory mem, immI16 src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6371
  predicate(UseStoreImmI16);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6372
  match(Set mem (StoreC mem src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6373
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6374
  ins_cost(150);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6375
  format %{ "MOV16  $mem,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6376
  opcode(0xC7);     /* C7 /0 Same as 32 store immediate with prefix */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6377
  ins_encode( SizePrefix, OpcP, RMopc_Mem(0x00,mem),  Con16( src ));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6378
  ins_pipe( ialu_mem_imm );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6379
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6380
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6381
// Store Pointer Immediate; null pointers or constant oops that do not
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6382
// need card-mark barriers.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6383
instruct storeImmP(memory mem, immP src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6384
  match(Set mem (StoreP mem src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6385
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6386
  ins_cost(150);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6387
  format %{ "MOV    $mem,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6388
  opcode(0xC7);               /* C7 /0 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6389
  ins_encode( OpcP, RMopc_Mem(0x00,mem),  Con32( src ));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6390
  ins_pipe( ialu_mem_imm );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6391
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6392
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6393
// Store Byte Immediate
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6394
instruct storeImmB(memory mem, immI8 src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6395
  match(Set mem (StoreB mem src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6396
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6397
  ins_cost(150);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6398
  format %{ "MOV8   $mem,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6399
  opcode(0xC6);               /* C6 /0 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6400
  ins_encode( OpcP, RMopc_Mem(0x00,mem),  Con8or32( src ));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6401
  ins_pipe( ialu_mem_imm );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6402
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6403
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6404
// Store CMS card-mark Immediate
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6405
instruct storeImmCM(memory mem, immI8 src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6406
  match(Set mem (StoreCM mem src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6407
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6408
  ins_cost(150);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6409
  format %{ "MOV8   $mem,$src\t! CMS card-mark imm0" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6410
  opcode(0xC6);               /* C6 /0 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6411
  ins_encode( OpcP, RMopc_Mem(0x00,mem),  Con8or32( src ));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6412
  ins_pipe( ialu_mem_imm );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6413
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6414
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6415
// Store Double
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  6416
instruct storeDPR( memory mem, regDPR1 src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6417
  predicate(UseSSE<=1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6418
  match(Set mem (StoreD mem src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6419
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6420
  ins_cost(100);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6421
  format %{ "FST_D  $mem,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6422
  opcode(0xDD);       /* DD /2 */
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  6423
  ins_encode( enc_FPR_store(mem,src) );
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6424
  ins_pipe( fpu_mem_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6425
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6426
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6427
// Store double does rounding on x86
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  6428
instruct storeDPR_rounded( memory mem, regDPR1 src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6429
  predicate(UseSSE<=1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6430
  match(Set mem (StoreD mem (RoundDouble src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6431
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6432
  ins_cost(100);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6433
  format %{ "FST_D  $mem,$src\t# round" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6434
  opcode(0xDD);       /* DD /2 */
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  6435
  ins_encode( enc_FPR_store(mem,src) );
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6436
  ins_pipe( fpu_mem_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6437
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6438
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6439
// Store XMM register to memory (double-precision floating points)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6440
// MOVSD instruction
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  6441
instruct storeD(memory mem, regD src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6442
  predicate(UseSSE>=2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6443
  match(Set mem (StoreD mem src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6444
  ins_cost(95);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6445
  format %{ "MOVSD  $mem,$src" %}
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  6446
  ins_encode %{
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  6447
    __ movdbl($mem$$Address, $src$$XMMRegister);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  6448
  %}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6449
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6450
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6451
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6452
// Store XMM register to memory (single-precision floating point)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6453
// MOVSS instruction
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  6454
instruct storeF(memory mem, regF src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6455
  predicate(UseSSE>=1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6456
  match(Set mem (StoreF mem src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6457
  ins_cost(95);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6458
  format %{ "MOVSS  $mem,$src" %}
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  6459
  ins_encode %{
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  6460
    __ movflt($mem$$Address, $src$$XMMRegister);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  6461
  %}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6462
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6463
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6464
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6465
// Store Float
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  6466
instruct storeFPR( memory mem, regFPR1 src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6467
  predicate(UseSSE==0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6468
  match(Set mem (StoreF mem src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6469
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6470
  ins_cost(100);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6471
  format %{ "FST_S  $mem,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6472
  opcode(0xD9);       /* D9 /2 */
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  6473
  ins_encode( enc_FPR_store(mem,src) );
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6474
  ins_pipe( fpu_mem_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6475
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6476
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6477
// Store Float does rounding on x86
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  6478
instruct storeFPR_rounded( memory mem, regFPR1 src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6479
  predicate(UseSSE==0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6480
  match(Set mem (StoreF mem (RoundFloat src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6481
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6482
  ins_cost(100);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6483
  format %{ "FST_S  $mem,$src\t# round" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6484
  opcode(0xD9);       /* D9 /2 */
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  6485
  ins_encode( enc_FPR_store(mem,src) );
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6486
  ins_pipe( fpu_mem_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6487
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6488
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6489
// Store Float does rounding on x86
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  6490
instruct storeFPR_Drounded( memory mem, regDPR1 src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6491
  predicate(UseSSE<=1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6492
  match(Set mem (StoreF mem (ConvD2F src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6493
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6494
  ins_cost(100);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6495
  format %{ "FST_S  $mem,$src\t# D-round" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6496
  opcode(0xD9);       /* D9 /2 */
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  6497
  ins_encode( enc_FPR_store(mem,src) );
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6498
  ins_pipe( fpu_mem_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6499
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6500
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6501
// Store immediate Float value (it is faster than store from FPU register)
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  6502
// The instruction usage is guarded by predicate in operand immFPR().
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  6503
instruct storeFPR_imm( memory mem, immFPR src) %{
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  6504
  match(Set mem (StoreF mem src));
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  6505
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  6506
  ins_cost(50);
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  6507
  format %{ "MOV    $mem,$src\t# store float" %}
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  6508
  opcode(0xC7);               /* C7 /0 */
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  6509
  ins_encode( OpcP, RMopc_Mem(0x00,mem),  Con32FPR_as_bits( src ));
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  6510
  ins_pipe( ialu_mem_imm );
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  6511
%}
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  6512
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  6513
// Store immediate Float value (it is faster than store from XMM register)
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6514
// The instruction usage is guarded by predicate in operand immF().
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6515
instruct storeF_imm( memory mem, immF src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6516
  match(Set mem (StoreF mem src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6517
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6518
  ins_cost(50);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6519
  format %{ "MOV    $mem,$src\t# store float" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6520
  opcode(0xC7);               /* C7 /0 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6521
  ins_encode( OpcP, RMopc_Mem(0x00,mem),  Con32F_as_bits( src ));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6522
  ins_pipe( ialu_mem_imm );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6523
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6524
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6525
// Store Integer to stack slot
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  6526
instruct storeSSI(stackSlotI dst, rRegI src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6527
  match(Set dst src);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6528
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6529
  ins_cost(100);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6530
  format %{ "MOV    $dst,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6531
  opcode(0x89);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6532
  ins_encode( OpcPRegSS( dst, src ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6533
  ins_pipe( ialu_mem_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6534
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6535
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6536
// Store Integer to stack slot
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6537
instruct storeSSP(stackSlotP dst, eRegP src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6538
  match(Set dst src);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6539
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6540
  ins_cost(100);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6541
  format %{ "MOV    $dst,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6542
  opcode(0x89);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6543
  ins_encode( OpcPRegSS( dst, src ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6544
  ins_pipe( ialu_mem_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6545
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6546
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6547
// Store Long to stack slot
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6548
instruct storeSSL(stackSlotL dst, eRegL src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6549
  match(Set dst src);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6550
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6551
  ins_cost(200);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6552
  format %{ "MOV    $dst,$src.lo\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6553
            "MOV    $dst+4,$src.hi" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6554
  opcode(0x89, 0x89);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6555
  ins_encode( OpcP, RegMem( src, dst ), OpcS, RegMem_Hi( src, dst ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6556
  ins_pipe( ialu_mem_long_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6557
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6558
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6559
//----------MemBar Instructions-----------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6560
// Memory barrier flavors
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6561
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6562
instruct membar_acquire() %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6563
  match(MemBarAcquire);
22855
d637fd28a6c3 8028515: PPPC64 (part 113.2): opto: Introduce LoadFence/StoreFence.
goetz
parents: 22844
diff changeset
  6564
  match(LoadFence);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6565
  ins_cost(400);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6566
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6567
  size(0);
2338
a8660a1b709b 6822204: volatile fences should prefer lock:addl to actual mfence instructions
never
parents: 2259
diff changeset
  6568
  format %{ "MEMBAR-acquire ! (empty encoding)" %}
a8660a1b709b 6822204: volatile fences should prefer lock:addl to actual mfence instructions
never
parents: 2259
diff changeset
  6569
  ins_encode();
a8660a1b709b 6822204: volatile fences should prefer lock:addl to actual mfence instructions
never
parents: 2259
diff changeset
  6570
  ins_pipe(empty);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6571
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6572
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6573
instruct membar_acquire_lock() %{
10262
c5f62d314bee 7074017: Introduce MemBarAcquireLock/MemBarReleaseLock nodes for monitor enter/exit code paths
roland
parents: 10255
diff changeset
  6574
  match(MemBarAcquireLock);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6575
  ins_cost(0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6576
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6577
  size(0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6578
  format %{ "MEMBAR-acquire (prior CMPXCHG in FastLock so empty encoding)" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6579
  ins_encode( );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6580
  ins_pipe(empty);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6581
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6582
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6583
instruct membar_release() %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6584
  match(MemBarRelease);
22855
d637fd28a6c3 8028515: PPPC64 (part 113.2): opto: Introduce LoadFence/StoreFence.
goetz
parents: 22844
diff changeset
  6585
  match(StoreFence);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6586
  ins_cost(400);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6587
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6588
  size(0);
2338
a8660a1b709b 6822204: volatile fences should prefer lock:addl to actual mfence instructions
never
parents: 2259
diff changeset
  6589
  format %{ "MEMBAR-release ! (empty encoding)" %}
a8660a1b709b 6822204: volatile fences should prefer lock:addl to actual mfence instructions
never
parents: 2259
diff changeset
  6590
  ins_encode( );
a8660a1b709b 6822204: volatile fences should prefer lock:addl to actual mfence instructions
never
parents: 2259
diff changeset
  6591
  ins_pipe(empty);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6592
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6593
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6594
instruct membar_release_lock() %{
10262
c5f62d314bee 7074017: Introduce MemBarAcquireLock/MemBarReleaseLock nodes for monitor enter/exit code paths
roland
parents: 10255
diff changeset
  6595
  match(MemBarReleaseLock);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6596
  ins_cost(0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6597
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6598
  size(0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6599
  format %{ "MEMBAR-release (a FastUnlock follows so empty encoding)" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6600
  ins_encode( );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6601
  ins_pipe(empty);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6602
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6603
2338
a8660a1b709b 6822204: volatile fences should prefer lock:addl to actual mfence instructions
never
parents: 2259
diff changeset
  6604
instruct membar_volatile(eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6605
  match(MemBarVolatile);
2338
a8660a1b709b 6822204: volatile fences should prefer lock:addl to actual mfence instructions
never
parents: 2259
diff changeset
  6606
  effect(KILL cr);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6607
  ins_cost(400);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6608
30624
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
  6609
  format %{
2338
a8660a1b709b 6822204: volatile fences should prefer lock:addl to actual mfence instructions
never
parents: 2259
diff changeset
  6610
    $$template
a8660a1b709b 6822204: volatile fences should prefer lock:addl to actual mfence instructions
never
parents: 2259
diff changeset
  6611
    if (os::is_MP()) {
a8660a1b709b 6822204: volatile fences should prefer lock:addl to actual mfence instructions
never
parents: 2259
diff changeset
  6612
      $$emit$$"LOCK ADDL [ESP + #0], 0\t! membar_volatile"
a8660a1b709b 6822204: volatile fences should prefer lock:addl to actual mfence instructions
never
parents: 2259
diff changeset
  6613
    } else {
a8660a1b709b 6822204: volatile fences should prefer lock:addl to actual mfence instructions
never
parents: 2259
diff changeset
  6614
      $$emit$$"MEMBAR-volatile ! (empty encoding)"
a8660a1b709b 6822204: volatile fences should prefer lock:addl to actual mfence instructions
never
parents: 2259
diff changeset
  6615
    }
a8660a1b709b 6822204: volatile fences should prefer lock:addl to actual mfence instructions
never
parents: 2259
diff changeset
  6616
  %}
a8660a1b709b 6822204: volatile fences should prefer lock:addl to actual mfence instructions
never
parents: 2259
diff changeset
  6617
  ins_encode %{
a8660a1b709b 6822204: volatile fences should prefer lock:addl to actual mfence instructions
never
parents: 2259
diff changeset
  6618
    __ membar(Assembler::StoreLoad);
a8660a1b709b 6822204: volatile fences should prefer lock:addl to actual mfence instructions
never
parents: 2259
diff changeset
  6619
  %}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6620
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6621
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6622
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6623
instruct unnecessary_membar_volatile() %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6624
  match(MemBarVolatile);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6625
  predicate(Matcher::post_store_load_barrier(n));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6626
  ins_cost(0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6627
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6628
  size(0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6629
  format %{ "MEMBAR-volatile (unnecessary so empty encoding)" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6630
  ins_encode( );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6631
  ins_pipe(empty);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6632
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6633
11431
5ca3a19e559a 7121140: Allocation paths require explicit memory synchronization operations for RMO systems
roland
parents: 11429
diff changeset
  6634
instruct membar_storestore() %{
5ca3a19e559a 7121140: Allocation paths require explicit memory synchronization operations for RMO systems
roland
parents: 11429
diff changeset
  6635
  match(MemBarStoreStore);
5ca3a19e559a 7121140: Allocation paths require explicit memory synchronization operations for RMO systems
roland
parents: 11429
diff changeset
  6636
  ins_cost(0);
5ca3a19e559a 7121140: Allocation paths require explicit memory synchronization operations for RMO systems
roland
parents: 11429
diff changeset
  6637
5ca3a19e559a 7121140: Allocation paths require explicit memory synchronization operations for RMO systems
roland
parents: 11429
diff changeset
  6638
  size(0);
5ca3a19e559a 7121140: Allocation paths require explicit memory synchronization operations for RMO systems
roland
parents: 11429
diff changeset
  6639
  format %{ "MEMBAR-storestore (empty encoding)" %}
5ca3a19e559a 7121140: Allocation paths require explicit memory synchronization operations for RMO systems
roland
parents: 11429
diff changeset
  6640
  ins_encode( );
5ca3a19e559a 7121140: Allocation paths require explicit memory synchronization operations for RMO systems
roland
parents: 11429
diff changeset
  6641
  ins_pipe(empty);
5ca3a19e559a 7121140: Allocation paths require explicit memory synchronization operations for RMO systems
roland
parents: 11429
diff changeset
  6642
%}
5ca3a19e559a 7121140: Allocation paths require explicit memory synchronization operations for RMO systems
roland
parents: 11429
diff changeset
  6643
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6644
//----------Move Instructions--------------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6645
instruct castX2P(eAXRegP dst, eAXRegI src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6646
  match(Set dst (CastX2P src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6647
  format %{ "# X2P  $dst, $src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6648
  ins_encode( /*empty encoding*/ );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6649
  ins_cost(0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6650
  ins_pipe(empty);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6651
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6652
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  6653
instruct castP2X(rRegI dst, eRegP src ) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6654
  match(Set dst (CastP2X src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6655
  ins_cost(50);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6656
  format %{ "MOV    $dst, $src\t# CastP2X" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6657
  ins_encode( enc_Copy( dst, src) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6658
  ins_pipe( ialu_reg_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6659
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6660
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6661
//----------Conditional Move---------------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6662
// Conditional move
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  6663
instruct jmovI_reg(cmpOp cop, eFlagsReg cr, rRegI dst, rRegI src) %{
10971
db45f6ab9a75 7097546: Optimize use of CMOVE instructions
kvn
parents: 10267
diff changeset
  6664
  predicate(!VM_Version::supports_cmov() );
db45f6ab9a75 7097546: Optimize use of CMOVE instructions
kvn
parents: 10267
diff changeset
  6665
  match(Set dst (CMoveI (Binary cop cr) (Binary dst src)));
db45f6ab9a75 7097546: Optimize use of CMOVE instructions
kvn
parents: 10267
diff changeset
  6666
  ins_cost(200);
db45f6ab9a75 7097546: Optimize use of CMOVE instructions
kvn
parents: 10267
diff changeset
  6667
  format %{ "J$cop,us skip\t# signed cmove\n\t"
db45f6ab9a75 7097546: Optimize use of CMOVE instructions
kvn
parents: 10267
diff changeset
  6668
            "MOV    $dst,$src\n"
db45f6ab9a75 7097546: Optimize use of CMOVE instructions
kvn
parents: 10267
diff changeset
  6669
      "skip:" %}
db45f6ab9a75 7097546: Optimize use of CMOVE instructions
kvn
parents: 10267
diff changeset
  6670
  ins_encode %{
db45f6ab9a75 7097546: Optimize use of CMOVE instructions
kvn
parents: 10267
diff changeset
  6671
    Label Lskip;
db45f6ab9a75 7097546: Optimize use of CMOVE instructions
kvn
parents: 10267
diff changeset
  6672
    // Invert sense of branch from sense of CMOV
db45f6ab9a75 7097546: Optimize use of CMOVE instructions
kvn
parents: 10267
diff changeset
  6673
    __ jccb((Assembler::Condition)($cop$$cmpcode^1), Lskip);
db45f6ab9a75 7097546: Optimize use of CMOVE instructions
kvn
parents: 10267
diff changeset
  6674
    __ movl($dst$$Register, $src$$Register);
db45f6ab9a75 7097546: Optimize use of CMOVE instructions
kvn
parents: 10267
diff changeset
  6675
    __ bind(Lskip);
db45f6ab9a75 7097546: Optimize use of CMOVE instructions
kvn
parents: 10267
diff changeset
  6676
  %}
db45f6ab9a75 7097546: Optimize use of CMOVE instructions
kvn
parents: 10267
diff changeset
  6677
  ins_pipe( pipe_cmov_reg );
db45f6ab9a75 7097546: Optimize use of CMOVE instructions
kvn
parents: 10267
diff changeset
  6678
%}
db45f6ab9a75 7097546: Optimize use of CMOVE instructions
kvn
parents: 10267
diff changeset
  6679
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  6680
instruct jmovI_regU(cmpOpU cop, eFlagsRegU cr, rRegI dst, rRegI src) %{
10971
db45f6ab9a75 7097546: Optimize use of CMOVE instructions
kvn
parents: 10267
diff changeset
  6681
  predicate(!VM_Version::supports_cmov() );
db45f6ab9a75 7097546: Optimize use of CMOVE instructions
kvn
parents: 10267
diff changeset
  6682
  match(Set dst (CMoveI (Binary cop cr) (Binary dst src)));
db45f6ab9a75 7097546: Optimize use of CMOVE instructions
kvn
parents: 10267
diff changeset
  6683
  ins_cost(200);
db45f6ab9a75 7097546: Optimize use of CMOVE instructions
kvn
parents: 10267
diff changeset
  6684
  format %{ "J$cop,us skip\t# unsigned cmove\n\t"
db45f6ab9a75 7097546: Optimize use of CMOVE instructions
kvn
parents: 10267
diff changeset
  6685
            "MOV    $dst,$src\n"
db45f6ab9a75 7097546: Optimize use of CMOVE instructions
kvn
parents: 10267
diff changeset
  6686
      "skip:" %}
db45f6ab9a75 7097546: Optimize use of CMOVE instructions
kvn
parents: 10267
diff changeset
  6687
  ins_encode %{
db45f6ab9a75 7097546: Optimize use of CMOVE instructions
kvn
parents: 10267
diff changeset
  6688
    Label Lskip;
db45f6ab9a75 7097546: Optimize use of CMOVE instructions
kvn
parents: 10267
diff changeset
  6689
    // Invert sense of branch from sense of CMOV
db45f6ab9a75 7097546: Optimize use of CMOVE instructions
kvn
parents: 10267
diff changeset
  6690
    __ jccb((Assembler::Condition)($cop$$cmpcode^1), Lskip);
db45f6ab9a75 7097546: Optimize use of CMOVE instructions
kvn
parents: 10267
diff changeset
  6691
    __ movl($dst$$Register, $src$$Register);
db45f6ab9a75 7097546: Optimize use of CMOVE instructions
kvn
parents: 10267
diff changeset
  6692
    __ bind(Lskip);
db45f6ab9a75 7097546: Optimize use of CMOVE instructions
kvn
parents: 10267
diff changeset
  6693
  %}
db45f6ab9a75 7097546: Optimize use of CMOVE instructions
kvn
parents: 10267
diff changeset
  6694
  ins_pipe( pipe_cmov_reg );
db45f6ab9a75 7097546: Optimize use of CMOVE instructions
kvn
parents: 10267
diff changeset
  6695
%}
db45f6ab9a75 7097546: Optimize use of CMOVE instructions
kvn
parents: 10267
diff changeset
  6696
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  6697
instruct cmovI_reg(rRegI dst, rRegI src, eFlagsReg cr, cmpOp cop ) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6698
  predicate(VM_Version::supports_cmov() );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6699
  match(Set dst (CMoveI (Binary cop cr) (Binary dst src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6700
  ins_cost(200);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6701
  format %{ "CMOV$cop $dst,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6702
  opcode(0x0F,0x40);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6703
  ins_encode( enc_cmov(cop), RegReg( dst, src ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6704
  ins_pipe( pipe_cmov_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6705
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6706
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  6707
instruct cmovI_regU( cmpOpU cop, eFlagsRegU cr, rRegI dst, rRegI src ) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6708
  predicate(VM_Version::supports_cmov() );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6709
  match(Set dst (CMoveI (Binary cop cr) (Binary dst src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6710
  ins_cost(200);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6711
  format %{ "CMOV$cop $dst,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6712
  opcode(0x0F,0x40);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6713
  ins_encode( enc_cmov(cop), RegReg( dst, src ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6714
  ins_pipe( pipe_cmov_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6715
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6716
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  6717
instruct cmovI_regUCF( cmpOpUCF cop, eFlagsRegUCF cr, rRegI dst, rRegI src ) %{
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  6718
  predicate(VM_Version::supports_cmov() );
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  6719
  match(Set dst (CMoveI (Binary cop cr) (Binary dst src)));
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  6720
  ins_cost(200);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  6721
  expand %{
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  6722
    cmovI_regU(cop, cr, dst, src);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  6723
  %}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  6724
%}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  6725
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6726
// Conditional move
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  6727
instruct cmovI_mem(cmpOp cop, eFlagsReg cr, rRegI dst, memory src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6728
  predicate(VM_Version::supports_cmov() );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6729
  match(Set dst (CMoveI (Binary cop cr) (Binary dst (LoadI src))));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6730
  ins_cost(250);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6731
  format %{ "CMOV$cop $dst,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6732
  opcode(0x0F,0x40);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6733
  ins_encode( enc_cmov(cop), RegMem( dst, src ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6734
  ins_pipe( pipe_cmov_mem );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6735
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6736
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6737
// Conditional move
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  6738
instruct cmovI_memU(cmpOpU cop, eFlagsRegU cr, rRegI dst, memory src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6739
  predicate(VM_Version::supports_cmov() );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6740
  match(Set dst (CMoveI (Binary cop cr) (Binary dst (LoadI src))));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6741
  ins_cost(250);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6742
  format %{ "CMOV$cop $dst,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6743
  opcode(0x0F,0x40);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6744
  ins_encode( enc_cmov(cop), RegMem( dst, src ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6745
  ins_pipe( pipe_cmov_mem );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6746
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6747
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  6748
instruct cmovI_memUCF(cmpOpUCF cop, eFlagsRegUCF cr, rRegI dst, memory src) %{
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  6749
  predicate(VM_Version::supports_cmov() );
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  6750
  match(Set dst (CMoveI (Binary cop cr) (Binary dst (LoadI src))));
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  6751
  ins_cost(250);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  6752
  expand %{
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  6753
    cmovI_memU(cop, cr, dst, src);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  6754
  %}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  6755
%}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  6756
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6757
// Conditional move
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6758
instruct cmovP_reg(eRegP dst, eRegP src, eFlagsReg cr, cmpOp cop ) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6759
  predicate(VM_Version::supports_cmov() );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6760
  match(Set dst (CMoveP (Binary cop cr) (Binary dst src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6761
  ins_cost(200);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6762
  format %{ "CMOV$cop $dst,$src\t# ptr" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6763
  opcode(0x0F,0x40);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6764
  ins_encode( enc_cmov(cop), RegReg( dst, src ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6765
  ins_pipe( pipe_cmov_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6766
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6767
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6768
// Conditional move (non-P6 version)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6769
// Note:  a CMoveP is generated for  stubs and native wrappers
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6770
//        regardless of whether we are on a P6, so we
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6771
//        emulate a cmov here
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6772
instruct cmovP_reg_nonP6(eRegP dst, eRegP src, eFlagsReg cr, cmpOp cop ) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6773
  match(Set dst (CMoveP (Binary cop cr) (Binary dst src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6774
  ins_cost(300);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6775
  format %{ "Jn$cop   skip\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6776
          "MOV    $dst,$src\t# pointer\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6777
      "skip:" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6778
  opcode(0x8b);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6779
  ins_encode( enc_cmov_branch(cop, 0x2), OpcP, RegReg(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6780
  ins_pipe( pipe_cmov_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6781
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6782
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6783
// Conditional move
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  6784
instruct cmovP_regU(cmpOpU cop, eFlagsRegU cr, eRegP dst, eRegP src ) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6785
  predicate(VM_Version::supports_cmov() );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6786
  match(Set dst (CMoveP (Binary cop cr) (Binary dst src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6787
  ins_cost(200);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6788
  format %{ "CMOV$cop $dst,$src\t# ptr" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6789
  opcode(0x0F,0x40);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6790
  ins_encode( enc_cmov(cop), RegReg( dst, src ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6791
  ins_pipe( pipe_cmov_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6792
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6793
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  6794
instruct cmovP_regUCF(cmpOpUCF cop, eFlagsRegUCF cr, eRegP dst, eRegP src ) %{
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  6795
  predicate(VM_Version::supports_cmov() );
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  6796
  match(Set dst (CMoveP (Binary cop cr) (Binary dst src)));
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  6797
  ins_cost(200);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  6798
  expand %{
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  6799
    cmovP_regU(cop, cr, dst, src);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  6800
  %}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  6801
%}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  6802
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6803
// DISABLED: Requires the ADLC to emit a bottom_type call that
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6804
// correctly meets the two pointer arguments; one is an incoming
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6805
// register but the other is a memory operand.  ALSO appears to
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6806
// be buggy with implicit null checks.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6807
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6808
//// Conditional move
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6809
//instruct cmovP_mem(cmpOp cop, eFlagsReg cr, eRegP dst, memory src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6810
//  predicate(VM_Version::supports_cmov() );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6811
//  match(Set dst (CMoveP (Binary cop cr) (Binary dst (LoadP src))));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6812
//  ins_cost(250);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6813
//  format %{ "CMOV$cop $dst,$src\t# ptr" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6814
//  opcode(0x0F,0x40);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6815
//  ins_encode( enc_cmov(cop), RegMem( dst, src ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6816
//  ins_pipe( pipe_cmov_mem );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6817
//%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6818
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6819
//// Conditional move
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6820
//instruct cmovP_memU(cmpOpU cop, eFlagsRegU cr, eRegP dst, memory src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6821
//  predicate(VM_Version::supports_cmov() );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6822
//  match(Set dst (CMoveP (Binary cop cr) (Binary dst (LoadP src))));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6823
//  ins_cost(250);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6824
//  format %{ "CMOV$cop $dst,$src\t# ptr" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6825
//  opcode(0x0F,0x40);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6826
//  ins_encode( enc_cmov(cop), RegMem( dst, src ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6827
//  ins_pipe( pipe_cmov_mem );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6828
//%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6829
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6830
// Conditional move
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  6831
instruct fcmovDPR_regU(cmpOp_fcmov cop, eFlagsRegU cr, regDPR1 dst, regDPR src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6832
  predicate(UseSSE<=1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6833
  match(Set dst (CMoveD (Binary cop cr) (Binary dst src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6834
  ins_cost(200);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6835
  format %{ "FCMOV$cop $dst,$src\t# double" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6836
  opcode(0xDA);
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  6837
  ins_encode( enc_cmov_dpr(cop,src) );
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  6838
  ins_pipe( pipe_cmovDPR_reg );
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6839
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6840
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6841
// Conditional move
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  6842
instruct fcmovFPR_regU(cmpOp_fcmov cop, eFlagsRegU cr, regFPR1 dst, regFPR src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6843
  predicate(UseSSE==0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6844
  match(Set dst (CMoveF (Binary cop cr) (Binary dst src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6845
  ins_cost(200);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6846
  format %{ "FCMOV$cop $dst,$src\t# float" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6847
  opcode(0xDA);
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  6848
  ins_encode( enc_cmov_dpr(cop,src) );
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  6849
  ins_pipe( pipe_cmovDPR_reg );
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6850
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6851
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6852
// Float CMOV on Intel doesn't handle *signed* compares, only unsigned.
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  6853
instruct fcmovDPR_regS(cmpOp cop, eFlagsReg cr, regDPR dst, regDPR src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6854
  predicate(UseSSE<=1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6855
  match(Set dst (CMoveD (Binary cop cr) (Binary dst src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6856
  ins_cost(200);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6857
  format %{ "Jn$cop   skip\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6858
            "MOV    $dst,$src\t# double\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6859
      "skip:" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6860
  opcode (0xdd, 0x3);     /* DD D8+i or DD /3 */
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  6861
  ins_encode( enc_cmov_branch( cop, 0x4 ), Push_Reg_DPR(src), OpcP, RegOpc(dst) );
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  6862
  ins_pipe( pipe_cmovDPR_reg );
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6863
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6864
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6865
// Float CMOV on Intel doesn't handle *signed* compares, only unsigned.
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  6866
instruct fcmovFPR_regS(cmpOp cop, eFlagsReg cr, regFPR dst, regFPR src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6867
  predicate(UseSSE==0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6868
  match(Set dst (CMoveF (Binary cop cr) (Binary dst src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6869
  ins_cost(200);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6870
  format %{ "Jn$cop    skip\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6871
            "MOV    $dst,$src\t# float\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6872
      "skip:" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6873
  opcode (0xdd, 0x3);     /* DD D8+i or DD /3 */
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  6874
  ins_encode( enc_cmov_branch( cop, 0x4 ), Push_Reg_FPR(src), OpcP, RegOpc(dst) );
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  6875
  ins_pipe( pipe_cmovDPR_reg );
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6876
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6877
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6878
// No CMOVE with SSE/SSE2
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  6879
instruct fcmovF_regS(cmpOp cop, eFlagsReg cr, regF dst, regF src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6880
  predicate (UseSSE>=1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6881
  match(Set dst (CMoveF (Binary cop cr) (Binary dst src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6882
  ins_cost(200);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6883
  format %{ "Jn$cop   skip\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6884
            "MOVSS  $dst,$src\t# float\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6885
      "skip:" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6886
  ins_encode %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6887
    Label skip;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6888
    // Invert sense of branch from sense of CMOV
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6889
    __ jccb((Assembler::Condition)($cop$$cmpcode^1), skip);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6890
    __ movflt($dst$$XMMRegister, $src$$XMMRegister);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6891
    __ bind(skip);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6892
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6893
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6894
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6895
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6896
// No CMOVE with SSE/SSE2
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  6897
instruct fcmovD_regS(cmpOp cop, eFlagsReg cr, regD dst, regD src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6898
  predicate (UseSSE>=2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6899
  match(Set dst (CMoveD (Binary cop cr) (Binary dst src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6900
  ins_cost(200);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6901
  format %{ "Jn$cop   skip\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6902
            "MOVSD  $dst,$src\t# float\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6903
      "skip:" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6904
  ins_encode %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6905
    Label skip;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6906
    // Invert sense of branch from sense of CMOV
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6907
    __ jccb((Assembler::Condition)($cop$$cmpcode^1), skip);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6908
    __ movdbl($dst$$XMMRegister, $src$$XMMRegister);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6909
    __ bind(skip);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6910
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6911
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6912
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6913
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6914
// unsigned version
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  6915
instruct fcmovF_regU(cmpOpU cop, eFlagsRegU cr, regF dst, regF src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6916
  predicate (UseSSE>=1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6917
  match(Set dst (CMoveF (Binary cop cr) (Binary dst src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6918
  ins_cost(200);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6919
  format %{ "Jn$cop   skip\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6920
            "MOVSS  $dst,$src\t# float\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6921
      "skip:" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6922
  ins_encode %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6923
    Label skip;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6924
    // Invert sense of branch from sense of CMOV
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6925
    __ jccb((Assembler::Condition)($cop$$cmpcode^1), skip);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6926
    __ movflt($dst$$XMMRegister, $src$$XMMRegister);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6927
    __ bind(skip);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6928
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6929
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6930
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6931
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  6932
instruct fcmovF_regUCF(cmpOpUCF cop, eFlagsRegUCF cr, regF dst, regF src) %{
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  6933
  predicate (UseSSE>=1);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  6934
  match(Set dst (CMoveF (Binary cop cr) (Binary dst src)));
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  6935
  ins_cost(200);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  6936
  expand %{
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  6937
    fcmovF_regU(cop, cr, dst, src);
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  6938
  %}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  6939
%}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  6940
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6941
// unsigned version
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  6942
instruct fcmovD_regU(cmpOpU cop, eFlagsRegU cr, regD dst, regD src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6943
  predicate (UseSSE>=2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6944
  match(Set dst (CMoveD (Binary cop cr) (Binary dst src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6945
  ins_cost(200);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6946
  format %{ "Jn$cop   skip\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6947
            "MOVSD  $dst,$src\t# float\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6948
      "skip:" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6949
  ins_encode %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6950
    Label skip;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6951
    // Invert sense of branch from sense of CMOV
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6952
    __ jccb((Assembler::Condition)($cop$$cmpcode^1), skip);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6953
    __ movdbl($dst$$XMMRegister, $src$$XMMRegister);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6954
    __ bind(skip);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6955
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6956
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6957
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6958
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  6959
instruct fcmovD_regUCF(cmpOpUCF cop, eFlagsRegUCF cr, regD dst, regD src) %{
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  6960
  predicate (UseSSE>=2);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  6961
  match(Set dst (CMoveD (Binary cop cr) (Binary dst src)));
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  6962
  ins_cost(200);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  6963
  expand %{
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  6964
    fcmovD_regU(cop, cr, dst, src);
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  6965
  %}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  6966
%}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  6967
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6968
instruct cmovL_reg(cmpOp cop, eFlagsReg cr, eRegL dst, eRegL src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6969
  predicate(VM_Version::supports_cmov() );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6970
  match(Set dst (CMoveL (Binary cop cr) (Binary dst src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6971
  ins_cost(200);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6972
  format %{ "CMOV$cop $dst.lo,$src.lo\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6973
            "CMOV$cop $dst.hi,$src.hi" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6974
  opcode(0x0F,0x40);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6975
  ins_encode( enc_cmov(cop), RegReg_Lo2( dst, src ), enc_cmov(cop), RegReg_Hi2( dst, src ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6976
  ins_pipe( pipe_cmov_reg_long );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6977
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6978
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6979
instruct cmovL_regU(cmpOpU cop, eFlagsRegU cr, eRegL dst, eRegL src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6980
  predicate(VM_Version::supports_cmov() );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6981
  match(Set dst (CMoveL (Binary cop cr) (Binary dst src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6982
  ins_cost(200);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6983
  format %{ "CMOV$cop $dst.lo,$src.lo\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6984
            "CMOV$cop $dst.hi,$src.hi" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6985
  opcode(0x0F,0x40);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6986
  ins_encode( enc_cmov(cop), RegReg_Lo2( dst, src ), enc_cmov(cop), RegReg_Hi2( dst, src ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6987
  ins_pipe( pipe_cmov_reg_long );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6988
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6989
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  6990
instruct cmovL_regUCF(cmpOpUCF cop, eFlagsRegUCF cr, eRegL dst, eRegL src) %{
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  6991
  predicate(VM_Version::supports_cmov() );
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  6992
  match(Set dst (CMoveL (Binary cop cr) (Binary dst src)));
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  6993
  ins_cost(200);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  6994
  expand %{
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  6995
    cmovL_regU(cop, cr, dst, src);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  6996
  %}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  6997
%}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  6998
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6999
//----------Arithmetic Instructions--------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7000
//----------Addition Instructions----------------------------------------------
20289
35d78de0c547 8024924: Intrinsify java.lang.Math.addExact
rbackman
parents: 17095
diff changeset
  7001
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7002
// Integer Addition Instructions
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  7003
instruct addI_eReg(rRegI dst, rRegI src, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7004
  match(Set dst (AddI dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7005
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7006
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7007
  size(2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7008
  format %{ "ADD    $dst,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7009
  opcode(0x03);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7010
  ins_encode( OpcP, RegReg( dst, src) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7011
  ins_pipe( ialu_reg_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7012
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7013
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  7014
instruct addI_eReg_imm(rRegI dst, immI src, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7015
  match(Set dst (AddI dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7016
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7017
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7018
  format %{ "ADD    $dst,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7019
  opcode(0x81, 0x00); /* /0 id */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7020
  ins_encode( OpcSErm( dst, src ), Con8or32( src ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7021
  ins_pipe( ialu_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7022
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7023
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  7024
instruct incI_eReg(rRegI dst, immI1 src, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7025
  predicate(UseIncDec);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7026
  match(Set dst (AddI dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7027
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7028
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7029
  size(1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7030
  format %{ "INC    $dst" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7031
  opcode(0x40); /*  */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7032
  ins_encode( Opc_plus( primary, dst ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7033
  ins_pipe( ialu_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7034
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7035
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  7036
instruct leaI_eReg_immI(rRegI dst, rRegI src0, immI src1) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7037
  match(Set dst (AddI src0 src1));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7038
  ins_cost(110);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7039
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7040
  format %{ "LEA    $dst,[$src0 + $src1]" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7041
  opcode(0x8D); /* 0x8D /r */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7042
  ins_encode( OpcP, RegLea( dst, src0, src1 ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7043
  ins_pipe( ialu_reg_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7044
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7045
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7046
instruct leaP_eReg_immI(eRegP dst, eRegP src0, immI src1) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7047
  match(Set dst (AddP src0 src1));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7048
  ins_cost(110);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7049
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7050
  format %{ "LEA    $dst,[$src0 + $src1]\t# ptr" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7051
  opcode(0x8D); /* 0x8D /r */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7052
  ins_encode( OpcP, RegLea( dst, src0, src1 ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7053
  ins_pipe( ialu_reg_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7054
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7055
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  7056
instruct decI_eReg(rRegI dst, immI_M1 src, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7057
  predicate(UseIncDec);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7058
  match(Set dst (AddI dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7059
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7060
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7061
  size(1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7062
  format %{ "DEC    $dst" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7063
  opcode(0x48); /*  */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7064
  ins_encode( Opc_plus( primary, dst ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7065
  ins_pipe( ialu_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7066
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7067
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  7068
instruct addP_eReg(eRegP dst, rRegI src, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7069
  match(Set dst (AddP dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7070
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7071
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7072
  size(2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7073
  format %{ "ADD    $dst,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7074
  opcode(0x03);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7075
  ins_encode( OpcP, RegReg( dst, src) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7076
  ins_pipe( ialu_reg_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7077
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7078
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7079
instruct addP_eReg_imm(eRegP dst, immI src, eFlagsReg cr) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7080
  match(Set dst (AddP dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7081
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7082
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7083
  format %{ "ADD    $dst,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7084
  opcode(0x81,0x00); /* Opcode 81 /0 id */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7085
  // ins_encode( RegImm( dst, src) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7086
  ins_encode( OpcSErm( dst, src ), Con8or32( src ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7087
  ins_pipe( ialu_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7088
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7089
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  7090
instruct addI_eReg_mem(rRegI dst, memory src, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7091
  match(Set dst (AddI dst (LoadI src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7092
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7093
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7094
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7095
  format %{ "ADD    $dst,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7096
  opcode(0x03);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7097
  ins_encode( OpcP, RegMem( dst, src) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7098
  ins_pipe( ialu_reg_mem );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7099
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7100
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  7101
instruct addI_mem_eReg(memory dst, rRegI src, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7102
  match(Set dst (StoreI dst (AddI (LoadI dst) src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7103
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7104
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7105
  ins_cost(150);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7106
  format %{ "ADD    $dst,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7107
  opcode(0x01);  /* Opcode 01 /r */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7108
  ins_encode( OpcP, RegMem( src, dst ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7109
  ins_pipe( ialu_mem_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7110
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7111
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7112
// Add Memory with Immediate
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7113
instruct addI_mem_imm(memory dst, immI src, eFlagsReg cr) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7114
  match(Set dst (StoreI dst (AddI (LoadI dst) src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7115
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7116
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7117
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7118
  format %{ "ADD    $dst,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7119
  opcode(0x81);               /* Opcode 81 /0 id */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7120
  ins_encode( OpcSE( src ), RMopc_Mem(0x00,dst), Con8or32( src ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7121
  ins_pipe( ialu_mem_imm );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7122
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7123
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7124
instruct incI_mem(memory dst, immI1 src, eFlagsReg cr) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7125
  match(Set dst (StoreI dst (AddI (LoadI dst) src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7126
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7127
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7128
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7129
  format %{ "INC    $dst" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7130
  opcode(0xFF);               /* Opcode FF /0 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7131
  ins_encode( OpcP, RMopc_Mem(0x00,dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7132
  ins_pipe( ialu_mem_imm );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7133
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7134
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7135
instruct decI_mem(memory dst, immI_M1 src, eFlagsReg cr) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7136
  match(Set dst (StoreI dst (AddI (LoadI dst) src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7137
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7138
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7139
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7140
  format %{ "DEC    $dst" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7141
  opcode(0xFF);               /* Opcode FF /1 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7142
  ins_encode( OpcP, RMopc_Mem(0x01,dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7143
  ins_pipe( ialu_mem_imm );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7144
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7145
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7146
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7147
instruct checkCastPP( eRegP dst ) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7148
  match(Set dst (CheckCastPP dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7149
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7150
  size(0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7151
  format %{ "#checkcastPP of $dst" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7152
  ins_encode( /*empty encoding*/ );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7153
  ins_pipe( empty );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7154
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7155
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7156
instruct castPP( eRegP dst ) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7157
  match(Set dst (CastPP dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7158
  format %{ "#castPP of $dst" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7159
  ins_encode( /*empty encoding*/ );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7160
  ins_pipe( empty );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7161
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7162
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  7163
instruct castII( rRegI dst ) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7164
  match(Set dst (CastII dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7165
  format %{ "#castII of $dst" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7166
  ins_encode( /*empty encoding*/ );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7167
  ins_cost(0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7168
  ins_pipe( empty );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7169
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7170
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7171
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7172
// Load-locked - same as a regular pointer load when used with compare-swap
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7173
instruct loadPLocked(eRegP dst, memory mem) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7174
  match(Set dst (LoadPLocked mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7175
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7176
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7177
  format %{ "MOV    $dst,$mem\t# Load ptr. locked" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7178
  opcode(0x8B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7179
  ins_encode( OpcP, RegMem(dst,mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7180
  ins_pipe( ialu_reg_mem );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7181
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7182
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7183
// Conditional-store of the updated heap-top.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7184
// Used during allocation of the shared heap.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7185
// Sets flags (EQ) on success.  Implemented with a CMPXCHG on Intel.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7186
instruct storePConditional( memory heap_top_ptr, eAXRegP oldval, eRegP newval, eFlagsReg cr ) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7187
  match(Set cr (StorePConditional heap_top_ptr (Binary oldval newval)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7188
  // EAX is killed if there is contention, but then it's also unused.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7189
  // In the common case of no contention, EAX holds the new oop address.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7190
  format %{ "CMPXCHG $heap_top_ptr,$newval\t# If EAX==$heap_top_ptr Then store $newval into $heap_top_ptr" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7191
  ins_encode( lock_prefix, Opcode(0x0F), Opcode(0xB1), RegMem(newval,heap_top_ptr) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7192
  ins_pipe( pipe_cmpxchg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7193
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7194
1500
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
  7195
// Conditional-store of an int value.
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
  7196
// ZF flag is set on success, reset otherwise.  Implemented with a CMPXCHG on Intel.
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  7197
instruct storeIConditional( memory mem, eAXRegI oldval, rRegI newval, eFlagsReg cr ) %{
1500
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
  7198
  match(Set cr (StoreIConditional mem (Binary oldval newval)));
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
  7199
  effect(KILL oldval);
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
  7200
  format %{ "CMPXCHG $mem,$newval\t# If EAX==$mem Then store $newval into $mem" %}
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
  7201
  ins_encode( lock_prefix, Opcode(0x0F), Opcode(0xB1), RegMem(newval, mem) );
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7202
  ins_pipe( pipe_cmpxchg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7203
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7204
1500
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
  7205
// Conditional-store of a long value.
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
  7206
// ZF flag is set on success, reset otherwise.  Implemented with a CMPXCHG8 on Intel.
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
  7207
instruct storeLConditional( memory mem, eADXRegL oldval, eBCXRegL newval, eFlagsReg cr ) %{
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
  7208
  match(Set cr (StoreLConditional mem (Binary oldval newval)));
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
  7209
  effect(KILL oldval);
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
  7210
  format %{ "XCHG   EBX,ECX\t# correct order for CMPXCHG8 instruction\n\t"
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
  7211
            "CMPXCHG8 $mem,ECX:EBX\t# If EDX:EAX==$mem Then store ECX:EBX into $mem\n\t"
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
  7212
            "XCHG   EBX,ECX"
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
  7213
  %}
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
  7214
  ins_encode %{
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
  7215
    // Note: we need to swap rbx, and rcx before and after the
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
  7216
    //       cmpxchg8 instruction because the instruction uses
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
  7217
    //       rcx as the high order word of the new value to store but
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
  7218
    //       our register encoding uses rbx.
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
  7219
    __ xchgl(as_Register(EBX_enc), as_Register(ECX_enc));
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
  7220
    if( os::is_MP() )
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
  7221
      __ lock();
2150
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  7222
    __ cmpxchg8($mem$$Address);
1500
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
  7223
    __ xchgl(as_Register(EBX_enc), as_Register(ECX_enc));
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
  7224
  %}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7225
  ins_pipe( pipe_cmpxchg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7226
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7227
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7228
// No flag versions for CompareAndSwap{P,I,L} because matcher can't match them
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7229
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  7230
instruct compareAndSwapL( rRegI res, eSIRegP mem_ptr, eADXRegL oldval, eBCXRegL newval, eFlagsReg cr ) %{
13886
8d82c4dfa722 7023898: Intrinsify AtomicLongFieldUpdater.getAndIncrement()
roland
parents: 13728
diff changeset
  7231
  predicate(VM_Version::supports_cx8());
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7232
  match(Set res (CompareAndSwapL mem_ptr (Binary oldval newval)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7233
  effect(KILL cr, KILL oldval);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7234
  format %{ "CMPXCHG8 [$mem_ptr],$newval\t# If EDX:EAX==[$mem_ptr] Then store $newval into [$mem_ptr]\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7235
            "MOV    $res,0\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7236
            "JNE,s  fail\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7237
            "MOV    $res,1\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7238
          "fail:" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7239
  ins_encode( enc_cmpxchg8(mem_ptr),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7240
              enc_flags_ne_to_boolean(res) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7241
  ins_pipe( pipe_cmpxchg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7242
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7243
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  7244
instruct compareAndSwapP( rRegI res,  pRegP mem_ptr, eAXRegP oldval, eCXRegP newval, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7245
  match(Set res (CompareAndSwapP mem_ptr (Binary oldval newval)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7246
  effect(KILL cr, KILL oldval);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7247
  format %{ "CMPXCHG [$mem_ptr],$newval\t# If EAX==[$mem_ptr] Then store $newval into [$mem_ptr]\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7248
            "MOV    $res,0\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7249
            "JNE,s  fail\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7250
            "MOV    $res,1\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7251
          "fail:" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7252
  ins_encode( enc_cmpxchg(mem_ptr), enc_flags_ne_to_boolean(res) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7253
  ins_pipe( pipe_cmpxchg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7254
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7255
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  7256
instruct compareAndSwapI( rRegI res, pRegP mem_ptr, eAXRegI oldval, eCXRegI newval, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7257
  match(Set res (CompareAndSwapI mem_ptr (Binary oldval newval)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7258
  effect(KILL cr, KILL oldval);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7259
  format %{ "CMPXCHG [$mem_ptr],$newval\t# If EAX==[$mem_ptr] Then store $newval into [$mem_ptr]\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7260
            "MOV    $res,0\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7261
            "JNE,s  fail\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7262
            "MOV    $res,1\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7263
          "fail:" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7264
  ins_encode( enc_cmpxchg(mem_ptr), enc_flags_ne_to_boolean(res) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7265
  ins_pipe( pipe_cmpxchg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7266
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7267
13886
8d82c4dfa722 7023898: Intrinsify AtomicLongFieldUpdater.getAndIncrement()
roland
parents: 13728
diff changeset
  7268
instruct xaddI_no_res( memory mem, Universe dummy, immI add, eFlagsReg cr) %{
8d82c4dfa722 7023898: Intrinsify AtomicLongFieldUpdater.getAndIncrement()
roland
parents: 13728
diff changeset
  7269
  predicate(n->as_LoadStore()->result_not_used());
8d82c4dfa722 7023898: Intrinsify AtomicLongFieldUpdater.getAndIncrement()
roland
parents: 13728
diff changeset
  7270
  match(Set dummy (GetAndAddI mem add));
8d82c4dfa722 7023898: Intrinsify AtomicLongFieldUpdater.getAndIncrement()
roland
parents: 13728
diff changeset
  7271
  effect(KILL cr);
8d82c4dfa722 7023898: Intrinsify AtomicLongFieldUpdater.getAndIncrement()
roland
parents: 13728
diff changeset
  7272
  format %{ "ADDL  [$mem],$add" %}
8d82c4dfa722 7023898: Intrinsify AtomicLongFieldUpdater.getAndIncrement()
roland
parents: 13728
diff changeset
  7273
  ins_encode %{
8d82c4dfa722 7023898: Intrinsify AtomicLongFieldUpdater.getAndIncrement()
roland
parents: 13728
diff changeset
  7274
    if (os::is_MP()) { __ lock(); }
8d82c4dfa722 7023898: Intrinsify AtomicLongFieldUpdater.getAndIncrement()
roland
parents: 13728
diff changeset
  7275
    __ addl($mem$$Address, $add$$constant);
8d82c4dfa722 7023898: Intrinsify AtomicLongFieldUpdater.getAndIncrement()
roland
parents: 13728
diff changeset
  7276
  %}
8d82c4dfa722 7023898: Intrinsify AtomicLongFieldUpdater.getAndIncrement()
roland
parents: 13728
diff changeset
  7277
  ins_pipe( pipe_cmpxchg );
8d82c4dfa722 7023898: Intrinsify AtomicLongFieldUpdater.getAndIncrement()
roland
parents: 13728
diff changeset
  7278
%}
8d82c4dfa722 7023898: Intrinsify AtomicLongFieldUpdater.getAndIncrement()
roland
parents: 13728
diff changeset
  7279
8d82c4dfa722 7023898: Intrinsify AtomicLongFieldUpdater.getAndIncrement()
roland
parents: 13728
diff changeset
  7280
instruct xaddI( memory mem, rRegI newval, eFlagsReg cr) %{
8d82c4dfa722 7023898: Intrinsify AtomicLongFieldUpdater.getAndIncrement()
roland
parents: 13728
diff changeset
  7281
  match(Set newval (GetAndAddI mem newval));
8d82c4dfa722 7023898: Intrinsify AtomicLongFieldUpdater.getAndIncrement()
roland
parents: 13728
diff changeset
  7282
  effect(KILL cr);
8d82c4dfa722 7023898: Intrinsify AtomicLongFieldUpdater.getAndIncrement()
roland
parents: 13728
diff changeset
  7283
  format %{ "XADDL  [$mem],$newval" %}
8d82c4dfa722 7023898: Intrinsify AtomicLongFieldUpdater.getAndIncrement()
roland
parents: 13728
diff changeset
  7284
  ins_encode %{
8d82c4dfa722 7023898: Intrinsify AtomicLongFieldUpdater.getAndIncrement()
roland
parents: 13728
diff changeset
  7285
    if (os::is_MP()) { __ lock(); }
8d82c4dfa722 7023898: Intrinsify AtomicLongFieldUpdater.getAndIncrement()
roland
parents: 13728
diff changeset
  7286
    __ xaddl($mem$$Address, $newval$$Register);
8d82c4dfa722 7023898: Intrinsify AtomicLongFieldUpdater.getAndIncrement()
roland
parents: 13728
diff changeset
  7287
  %}
8d82c4dfa722 7023898: Intrinsify AtomicLongFieldUpdater.getAndIncrement()
roland
parents: 13728
diff changeset
  7288
  ins_pipe( pipe_cmpxchg );
8d82c4dfa722 7023898: Intrinsify AtomicLongFieldUpdater.getAndIncrement()
roland
parents: 13728
diff changeset
  7289
%}
8d82c4dfa722 7023898: Intrinsify AtomicLongFieldUpdater.getAndIncrement()
roland
parents: 13728
diff changeset
  7290
8d82c4dfa722 7023898: Intrinsify AtomicLongFieldUpdater.getAndIncrement()
roland
parents: 13728
diff changeset
  7291
instruct xchgI( memory mem, rRegI newval) %{
8d82c4dfa722 7023898: Intrinsify AtomicLongFieldUpdater.getAndIncrement()
roland
parents: 13728
diff changeset
  7292
  match(Set newval (GetAndSetI mem newval));
8d82c4dfa722 7023898: Intrinsify AtomicLongFieldUpdater.getAndIncrement()
roland
parents: 13728
diff changeset
  7293
  format %{ "XCHGL  $newval,[$mem]" %}
8d82c4dfa722 7023898: Intrinsify AtomicLongFieldUpdater.getAndIncrement()
roland
parents: 13728
diff changeset
  7294
  ins_encode %{
8d82c4dfa722 7023898: Intrinsify AtomicLongFieldUpdater.getAndIncrement()
roland
parents: 13728
diff changeset
  7295
    __ xchgl($newval$$Register, $mem$$Address);
8d82c4dfa722 7023898: Intrinsify AtomicLongFieldUpdater.getAndIncrement()
roland
parents: 13728
diff changeset
  7296
  %}
8d82c4dfa722 7023898: Intrinsify AtomicLongFieldUpdater.getAndIncrement()
roland
parents: 13728
diff changeset
  7297
  ins_pipe( pipe_cmpxchg );
8d82c4dfa722 7023898: Intrinsify AtomicLongFieldUpdater.getAndIncrement()
roland
parents: 13728
diff changeset
  7298
%}
8d82c4dfa722 7023898: Intrinsify AtomicLongFieldUpdater.getAndIncrement()
roland
parents: 13728
diff changeset
  7299
8d82c4dfa722 7023898: Intrinsify AtomicLongFieldUpdater.getAndIncrement()
roland
parents: 13728
diff changeset
  7300
instruct xchgP( memory mem, pRegP newval) %{
8d82c4dfa722 7023898: Intrinsify AtomicLongFieldUpdater.getAndIncrement()
roland
parents: 13728
diff changeset
  7301
  match(Set newval (GetAndSetP mem newval));
8d82c4dfa722 7023898: Intrinsify AtomicLongFieldUpdater.getAndIncrement()
roland
parents: 13728
diff changeset
  7302
  format %{ "XCHGL  $newval,[$mem]" %}
8d82c4dfa722 7023898: Intrinsify AtomicLongFieldUpdater.getAndIncrement()
roland
parents: 13728
diff changeset
  7303
  ins_encode %{
8d82c4dfa722 7023898: Intrinsify AtomicLongFieldUpdater.getAndIncrement()
roland
parents: 13728
diff changeset
  7304
    __ xchgl($newval$$Register, $mem$$Address);
8d82c4dfa722 7023898: Intrinsify AtomicLongFieldUpdater.getAndIncrement()
roland
parents: 13728
diff changeset
  7305
  %}
8d82c4dfa722 7023898: Intrinsify AtomicLongFieldUpdater.getAndIncrement()
roland
parents: 13728
diff changeset
  7306
  ins_pipe( pipe_cmpxchg );
8d82c4dfa722 7023898: Intrinsify AtomicLongFieldUpdater.getAndIncrement()
roland
parents: 13728
diff changeset
  7307
%}
8d82c4dfa722 7023898: Intrinsify AtomicLongFieldUpdater.getAndIncrement()
roland
parents: 13728
diff changeset
  7308
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7309
//----------Subtraction Instructions-------------------------------------------
21105
47618ee96ed5 8026844: Various Math functions needs intrinsification
rbackman
parents: 20300
diff changeset
  7310
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7311
// Integer Subtraction Instructions
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  7312
instruct subI_eReg(rRegI dst, rRegI src, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7313
  match(Set dst (SubI dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7314
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7315
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7316
  size(2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7317
  format %{ "SUB    $dst,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7318
  opcode(0x2B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7319
  ins_encode( OpcP, RegReg( dst, src) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7320
  ins_pipe( ialu_reg_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7321
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7322
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  7323
instruct subI_eReg_imm(rRegI dst, immI src, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7324
  match(Set dst (SubI dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7325
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7326
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7327
  format %{ "SUB    $dst,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7328
  opcode(0x81,0x05);  /* Opcode 81 /5 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7329
  // ins_encode( RegImm( dst, src) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7330
  ins_encode( OpcSErm( dst, src ), Con8or32( src ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7331
  ins_pipe( ialu_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7332
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7333
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  7334
instruct subI_eReg_mem(rRegI dst, memory src, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7335
  match(Set dst (SubI dst (LoadI src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7336
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7337
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7338
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7339
  format %{ "SUB    $dst,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7340
  opcode(0x2B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7341
  ins_encode( OpcP, RegMem( dst, src) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7342
  ins_pipe( ialu_reg_mem );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7343
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7344
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  7345
instruct subI_mem_eReg(memory dst, rRegI src, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7346
  match(Set dst (StoreI dst (SubI (LoadI dst) src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7347
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7348
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7349
  ins_cost(150);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7350
  format %{ "SUB    $dst,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7351
  opcode(0x29);  /* Opcode 29 /r */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7352
  ins_encode( OpcP, RegMem( src, dst ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7353
  ins_pipe( ialu_mem_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7354
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7355
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7356
// Subtract from a pointer
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  7357
instruct subP_eReg(eRegP dst, rRegI src, immI0 zero, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7358
  match(Set dst (AddP dst (SubI zero src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7359
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7360
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7361
  size(2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7362
  format %{ "SUB    $dst,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7363
  opcode(0x2B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7364
  ins_encode( OpcP, RegReg( dst, src) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7365
  ins_pipe( ialu_reg_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7366
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7367
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  7368
instruct negI_eReg(rRegI dst, immI0 zero, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7369
  match(Set dst (SubI zero dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7370
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7371
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7372
  size(2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7373
  format %{ "NEG    $dst" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7374
  opcode(0xF7,0x03);  // Opcode F7 /3
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7375
  ins_encode( OpcP, RegOpc( dst ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7376
  ins_pipe( ialu_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7377
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7378
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7379
//----------Multiplication/Division Instructions-------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7380
// Integer Multiplication Instructions
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7381
// Multiply Register
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  7382
instruct mulI_eReg(rRegI dst, rRegI src, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7383
  match(Set dst (MulI dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7384
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7385
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7386
  size(3);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7387
  ins_cost(300);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7388
  format %{ "IMUL   $dst,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7389
  opcode(0xAF, 0x0F);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7390
  ins_encode( OpcS, OpcP, RegReg( dst, src) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7391
  ins_pipe( ialu_reg_reg_alu0 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7392
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7393
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7394
// Multiply 32-bit Immediate
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  7395
instruct mulI_eReg_imm(rRegI dst, rRegI src, immI imm, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7396
  match(Set dst (MulI src imm));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7397
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7398
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7399
  ins_cost(300);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7400
  format %{ "IMUL   $dst,$src,$imm" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7401
  opcode(0x69);  /* 69 /r id */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7402
  ins_encode( OpcSE(imm), RegReg( dst, src ), Con8or32( imm ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7403
  ins_pipe( ialu_reg_reg_alu0 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7404
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7405
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7406
instruct loadConL_low_only(eADXRegL_low_only dst, immL32 src, eFlagsReg cr) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7407
  match(Set dst src);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7408
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7409
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7410
  // Note that this is artificially increased to make it more expensive than loadConL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7411
  ins_cost(250);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7412
  format %{ "MOV    EAX,$src\t// low word only" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7413
  opcode(0xB8);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7414
  ins_encode( LdImmL_Lo(dst, src) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7415
  ins_pipe( ialu_reg_fat );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7416
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7417
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7418
// Multiply by 32-bit Immediate, taking the shifted high order results
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7419
//  (special case for shift by 32)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7420
instruct mulI_imm_high(eDXRegI dst, nadxRegI src1, eADXRegL_low_only src2, immI_32 cnt, eFlagsReg cr) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7421
  match(Set dst (ConvL2I (RShiftL (MulL (ConvI2L src1) src2) cnt)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7422
  predicate( _kids[0]->_kids[0]->_kids[1]->_leaf->Opcode() == Op_ConL &&
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7423
             _kids[0]->_kids[0]->_kids[1]->_leaf->as_Type()->type()->is_long()->get_con() >= min_jint &&
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7424
             _kids[0]->_kids[0]->_kids[1]->_leaf->as_Type()->type()->is_long()->get_con() <= max_jint );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7425
  effect(USE src1, KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7426
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7427
  // Note that this is adjusted by 150 to compensate for the overcosting of loadConL_low_only
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7428
  ins_cost(0*100 + 1*400 - 150);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7429
  format %{ "IMUL   EDX:EAX,$src1" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7430
  ins_encode( multiply_con_and_shift_high( dst, src1, src2, cnt, cr ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7431
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7432
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7433
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7434
// Multiply by 32-bit Immediate, taking the shifted high order results
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7435
instruct mulI_imm_RShift_high(eDXRegI dst, nadxRegI src1, eADXRegL_low_only src2, immI_32_63 cnt, eFlagsReg cr) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7436
  match(Set dst (ConvL2I (RShiftL (MulL (ConvI2L src1) src2) cnt)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7437
  predicate( _kids[0]->_kids[0]->_kids[1]->_leaf->Opcode() == Op_ConL &&
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7438
             _kids[0]->_kids[0]->_kids[1]->_leaf->as_Type()->type()->is_long()->get_con() >= min_jint &&
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7439
             _kids[0]->_kids[0]->_kids[1]->_leaf->as_Type()->type()->is_long()->get_con() <= max_jint );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7440
  effect(USE src1, KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7441
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7442
  // Note that this is adjusted by 150 to compensate for the overcosting of loadConL_low_only
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7443
  ins_cost(1*100 + 1*400 - 150);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7444
  format %{ "IMUL   EDX:EAX,$src1\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7445
            "SAR    EDX,$cnt-32" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7446
  ins_encode( multiply_con_and_shift_high( dst, src1, src2, cnt, cr ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7447
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7448
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7449
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7450
// Multiply Memory 32-bit Immediate
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  7451
instruct mulI_mem_imm(rRegI dst, memory src, immI imm, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7452
  match(Set dst (MulI (LoadI src) imm));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7453
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7454
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7455
  ins_cost(300);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7456
  format %{ "IMUL   $dst,$src,$imm" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7457
  opcode(0x69);  /* 69 /r id */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7458
  ins_encode( OpcSE(imm), RegMem( dst, src ), Con8or32( imm ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7459
  ins_pipe( ialu_reg_mem_alu0 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7460
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7461
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7462
// Multiply Memory
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  7463
instruct mulI(rRegI dst, memory src, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7464
  match(Set dst (MulI dst (LoadI src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7465
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7466
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7467
  ins_cost(350);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7468
  format %{ "IMUL   $dst,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7469
  opcode(0xAF, 0x0F);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7470
  ins_encode( OpcS, OpcP, RegMem( dst, src) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7471
  ins_pipe( ialu_reg_mem_alu0 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7472
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7473
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7474
// Multiply Register Int to Long
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7475
instruct mulI2L(eADXRegL dst, eAXRegI src, nadxRegI src1, eFlagsReg flags) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7476
  // Basic Idea: long = (long)int * (long)int
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7477
  match(Set dst (MulL (ConvI2L src) (ConvI2L src1)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7478
  effect(DEF dst, USE src, USE src1, KILL flags);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7479
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7480
  ins_cost(300);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7481
  format %{ "IMUL   $dst,$src1" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7482
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7483
  ins_encode( long_int_multiply( dst, src1 ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7484
  ins_pipe( ialu_reg_reg_alu0 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7485
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7486
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7487
instruct mulIS_eReg(eADXRegL dst, immL_32bits mask, eFlagsReg flags, eAXRegI src, nadxRegI src1) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7488
  // Basic Idea:  long = (int & 0xffffffffL) * (int & 0xffffffffL)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7489
  match(Set dst (MulL (AndL (ConvI2L src) mask) (AndL (ConvI2L src1) mask)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7490
  effect(KILL flags);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7491
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7492
  ins_cost(300);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7493
  format %{ "MUL    $dst,$src1" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7494
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7495
  ins_encode( long_uint_multiply(dst, src1) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7496
  ins_pipe( ialu_reg_reg_alu0 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7497
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7498
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7499
// Multiply Register Long
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  7500
instruct mulL_eReg(eADXRegL dst, eRegL src, rRegI tmp, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7501
  match(Set dst (MulL dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7502
  effect(KILL cr, TEMP tmp);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7503
  ins_cost(4*100+3*400);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7504
// Basic idea: lo(result) = lo(x_lo * y_lo)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7505
//             hi(result) = hi(x_lo * y_lo) + lo(x_hi * y_lo) + lo(x_lo * y_hi)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7506
  format %{ "MOV    $tmp,$src.lo\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7507
            "IMUL   $tmp,EDX\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7508
            "MOV    EDX,$src.hi\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7509
            "IMUL   EDX,EAX\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7510
            "ADD    $tmp,EDX\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7511
            "MUL    EDX:EAX,$src.lo\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7512
            "ADD    EDX,$tmp" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7513
  ins_encode( long_multiply( dst, src, tmp ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7514
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7515
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7516
4757
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
  7517
// Multiply Register Long where the left operand's high 32 bits are zero
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  7518
instruct mulL_eReg_lhi0(eADXRegL dst, eRegL src, rRegI tmp, eFlagsReg cr) %{
4757
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
  7519
  predicate(is_operand_hi32_zero(n->in(1)));
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
  7520
  match(Set dst (MulL dst src));
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
  7521
  effect(KILL cr, TEMP tmp);
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
  7522
  ins_cost(2*100+2*400);
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
  7523
// Basic idea: lo(result) = lo(x_lo * y_lo)
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
  7524
//             hi(result) = hi(x_lo * y_lo) + lo(x_lo * y_hi) where lo(x_hi * y_lo) = 0 because x_hi = 0
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
  7525
  format %{ "MOV    $tmp,$src.hi\n\t"
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
  7526
            "IMUL   $tmp,EAX\n\t"
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
  7527
            "MUL    EDX:EAX,$src.lo\n\t"
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
  7528
            "ADD    EDX,$tmp" %}
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
  7529
  ins_encode %{
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
  7530
    __ movl($tmp$$Register, HIGH_FROM_LOW($src$$Register));
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
  7531
    __ imull($tmp$$Register, rax);
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
  7532
    __ mull($src$$Register);
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
  7533
    __ addl(rdx, $tmp$$Register);
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
  7534
  %}
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
  7535
  ins_pipe( pipe_slow );
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
  7536
%}
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
  7537
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
  7538
// Multiply Register Long where the right operand's high 32 bits are zero
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  7539
instruct mulL_eReg_rhi0(eADXRegL dst, eRegL src, rRegI tmp, eFlagsReg cr) %{
4757
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
  7540
  predicate(is_operand_hi32_zero(n->in(2)));
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
  7541
  match(Set dst (MulL dst src));
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
  7542
  effect(KILL cr, TEMP tmp);
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
  7543
  ins_cost(2*100+2*400);
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
  7544
// Basic idea: lo(result) = lo(x_lo * y_lo)
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
  7545
//             hi(result) = hi(x_lo * y_lo) + lo(x_hi * y_lo) where lo(x_lo * y_hi) = 0 because y_hi = 0
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
  7546
  format %{ "MOV    $tmp,$src.lo\n\t"
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
  7547
            "IMUL   $tmp,EDX\n\t"
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
  7548
            "MUL    EDX:EAX,$src.lo\n\t"
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
  7549
            "ADD    EDX,$tmp" %}
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
  7550
  ins_encode %{
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
  7551
    __ movl($tmp$$Register, $src$$Register);
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
  7552
    __ imull($tmp$$Register, rdx);
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
  7553
    __ mull($src$$Register);
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
  7554
    __ addl(rdx, $tmp$$Register);
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
  7555
  %}
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
  7556
  ins_pipe( pipe_slow );
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
  7557
%}
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
  7558
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
  7559
// Multiply Register Long where the left and the right operands' high 32 bits are zero
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
  7560
instruct mulL_eReg_hi0(eADXRegL dst, eRegL src, eFlagsReg cr) %{
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
  7561
  predicate(is_operand_hi32_zero(n->in(1)) && is_operand_hi32_zero(n->in(2)));
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
  7562
  match(Set dst (MulL dst src));
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
  7563
  effect(KILL cr);
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
  7564
  ins_cost(1*400);
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
  7565
// Basic idea: lo(result) = lo(x_lo * y_lo)
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
  7566
//             hi(result) = hi(x_lo * y_lo) where lo(x_hi * y_lo) = 0 and lo(x_lo * y_hi) = 0 because x_hi = 0 and y_hi = 0
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
  7567
  format %{ "MUL    EDX:EAX,$src.lo\n\t" %}
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
  7568
  ins_encode %{
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
  7569
    __ mull($src$$Register);
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
  7570
  %}
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
  7571
  ins_pipe( pipe_slow );
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
  7572
%}
1fe15ef4fc8a 6921969: optimize 64 long multiply for case with high bits zero
never
parents: 4566
diff changeset
  7573
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7574
// Multiply Register Long by small constant
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  7575
instruct mulL_eReg_con(eADXRegL dst, immL_127 src, rRegI tmp, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7576
  match(Set dst (MulL dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7577
  effect(KILL cr, TEMP tmp);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7578
  ins_cost(2*100+2*400);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7579
  size(12);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7580
// Basic idea: lo(result) = lo(src * EAX)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7581
//             hi(result) = hi(src * EAX) + lo(src * EDX)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7582
  format %{ "IMUL   $tmp,EDX,$src\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7583
            "MOV    EDX,$src\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7584
            "MUL    EDX\t# EDX*EAX -> EDX:EAX\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7585
            "ADD    EDX,$tmp" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7586
  ins_encode( long_multiply_con( dst, src, tmp ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7587
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7588
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7589
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7590
// Integer DIV with Register
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7591
instruct divI_eReg(eAXRegI rax, eDXRegI rdx, eCXRegI div, eFlagsReg cr) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7592
  match(Set rax (DivI rax div));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7593
  effect(KILL rdx, KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7594
  size(26);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7595
  ins_cost(30*100+10*100);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7596
  format %{ "CMP    EAX,0x80000000\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7597
            "JNE,s  normal\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7598
            "XOR    EDX,EDX\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7599
            "CMP    ECX,-1\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7600
            "JE,s   done\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7601
    "normal: CDQ\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7602
            "IDIV   $div\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7603
    "done:"        %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7604
  opcode(0xF7, 0x7);  /* Opcode F7 /7 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7605
  ins_encode( cdq_enc, OpcP, RegOpc(div) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7606
  ins_pipe( ialu_reg_reg_alu0 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7607
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7608
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7609
// Divide Register Long
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7610
instruct divL_eReg( eADXRegL dst, eRegL src1, eRegL src2, eFlagsReg cr, eCXRegI cx, eBXRegI bx ) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7611
  match(Set dst (DivL src1 src2));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7612
  effect( KILL cr, KILL cx, KILL bx );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7613
  ins_cost(10000);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7614
  format %{ "PUSH   $src1.hi\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7615
            "PUSH   $src1.lo\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7616
            "PUSH   $src2.hi\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7617
            "PUSH   $src2.lo\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7618
            "CALL   SharedRuntime::ldiv\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7619
            "ADD    ESP,16" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7620
  ins_encode( long_div(src1,src2) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7621
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7622
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7623
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7624
// Integer DIVMOD with Register, both quotient and mod results
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7625
instruct divModI_eReg_divmod(eAXRegI rax, eDXRegI rdx, eCXRegI div, eFlagsReg cr) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7626
  match(DivModI rax div);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7627
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7628
  size(26);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7629
  ins_cost(30*100+10*100);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7630
  format %{ "CMP    EAX,0x80000000\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7631
            "JNE,s  normal\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7632
            "XOR    EDX,EDX\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7633
            "CMP    ECX,-1\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7634
            "JE,s   done\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7635
    "normal: CDQ\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7636
            "IDIV   $div\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7637
    "done:"        %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7638
  opcode(0xF7, 0x7);  /* Opcode F7 /7 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7639
  ins_encode( cdq_enc, OpcP, RegOpc(div) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7640
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7641
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7642
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7643
// Integer MOD with Register
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7644
instruct modI_eReg(eDXRegI rdx, eAXRegI rax, eCXRegI div, eFlagsReg cr) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7645
  match(Set rdx (ModI rax div));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7646
  effect(KILL rax, KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7647
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7648
  size(26);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7649
  ins_cost(300);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7650
  format %{ "CDQ\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7651
            "IDIV   $div" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7652
  opcode(0xF7, 0x7);  /* Opcode F7 /7 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7653
  ins_encode( cdq_enc, OpcP, RegOpc(div) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7654
  ins_pipe( ialu_reg_reg_alu0 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7655
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7656
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7657
// Remainder Register Long
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7658
instruct modL_eReg( eADXRegL dst, eRegL src1, eRegL src2, eFlagsReg cr, eCXRegI cx, eBXRegI bx ) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7659
  match(Set dst (ModL src1 src2));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7660
  effect( KILL cr, KILL cx, KILL bx );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7661
  ins_cost(10000);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7662
  format %{ "PUSH   $src1.hi\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7663
            "PUSH   $src1.lo\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7664
            "PUSH   $src2.hi\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7665
            "PUSH   $src2.lo\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7666
            "CALL   SharedRuntime::lrem\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7667
            "ADD    ESP,16" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7668
  ins_encode( long_mod(src1,src2) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7669
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7670
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7671
7115
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  7672
// Divide Register Long (no special case since divisor != -1)
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  7673
instruct divL_eReg_imm32( eADXRegL dst, immL32 imm, rRegI tmp, rRegI tmp2, eFlagsReg cr ) %{
7115
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  7674
  match(Set dst (DivL dst imm));
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  7675
  effect( TEMP tmp, TEMP tmp2, KILL cr );
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  7676
  ins_cost(1000);
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  7677
  format %{ "MOV    $tmp,abs($imm) # ldiv EDX:EAX,$imm\n\t"
7121
69928525c55c 6997311: SIGFPE in new long division asm code
kvn
parents: 7115
diff changeset
  7678
            "XOR    $tmp2,$tmp2\n\t"
7115
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  7679
            "CMP    $tmp,EDX\n\t"
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  7680
            "JA,s   fast\n\t"
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  7681
            "MOV    $tmp2,EAX\n\t"
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  7682
            "MOV    EAX,EDX\n\t"
7121
69928525c55c 6997311: SIGFPE in new long division asm code
kvn
parents: 7115
diff changeset
  7683
            "MOV    EDX,0\n\t"
69928525c55c 6997311: SIGFPE in new long division asm code
kvn
parents: 7115
diff changeset
  7684
            "JLE,s  pos\n\t"
69928525c55c 6997311: SIGFPE in new long division asm code
kvn
parents: 7115
diff changeset
  7685
            "LNEG   EAX : $tmp2\n\t"
69928525c55c 6997311: SIGFPE in new long division asm code
kvn
parents: 7115
diff changeset
  7686
            "DIV    $tmp # unsigned division\n\t"
69928525c55c 6997311: SIGFPE in new long division asm code
kvn
parents: 7115
diff changeset
  7687
            "XCHG   EAX,$tmp2\n\t"
69928525c55c 6997311: SIGFPE in new long division asm code
kvn
parents: 7115
diff changeset
  7688
            "DIV    $tmp\n\t"
69928525c55c 6997311: SIGFPE in new long division asm code
kvn
parents: 7115
diff changeset
  7689
            "LNEG   $tmp2 : EAX\n\t"
7115
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  7690
            "JMP,s  done\n"
7121
69928525c55c 6997311: SIGFPE in new long division asm code
kvn
parents: 7115
diff changeset
  7691
    "pos:\n\t"
69928525c55c 6997311: SIGFPE in new long division asm code
kvn
parents: 7115
diff changeset
  7692
            "DIV    $tmp\n\t"
69928525c55c 6997311: SIGFPE in new long division asm code
kvn
parents: 7115
diff changeset
  7693
            "XCHG   EAX,$tmp2\n"
7115
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  7694
    "fast:\n\t"
7121
69928525c55c 6997311: SIGFPE in new long division asm code
kvn
parents: 7115
diff changeset
  7695
            "DIV    $tmp\n"
7115
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  7696
    "done:\n\t"
7121
69928525c55c 6997311: SIGFPE in new long division asm code
kvn
parents: 7115
diff changeset
  7697
            "MOV    EDX,$tmp2\n\t"
7115
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  7698
            "NEG    EDX:EAX # if $imm < 0" %}
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  7699
  ins_encode %{
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  7700
    int con = (int)$imm$$constant;
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  7701
    assert(con != 0 && con != -1 && con != min_jint, "wrong divisor");
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  7702
    int pcon = (con > 0) ? con : -con;
7121
69928525c55c 6997311: SIGFPE in new long division asm code
kvn
parents: 7115
diff changeset
  7703
    Label Lfast, Lpos, Ldone;
7115
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  7704
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  7705
    __ movl($tmp$$Register, pcon);
7121
69928525c55c 6997311: SIGFPE in new long division asm code
kvn
parents: 7115
diff changeset
  7706
    __ xorl($tmp2$$Register,$tmp2$$Register);
7115
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  7707
    __ cmpl($tmp$$Register, HIGH_FROM_LOW($dst$$Register));
7121
69928525c55c 6997311: SIGFPE in new long division asm code
kvn
parents: 7115
diff changeset
  7708
    __ jccb(Assembler::above, Lfast); // result fits into 32 bit
7115
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  7709
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  7710
    __ movl($tmp2$$Register, $dst$$Register); // save
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  7711
    __ movl($dst$$Register, HIGH_FROM_LOW($dst$$Register));
7121
69928525c55c 6997311: SIGFPE in new long division asm code
kvn
parents: 7115
diff changeset
  7712
    __ movl(HIGH_FROM_LOW($dst$$Register),0); // preserve flags
69928525c55c 6997311: SIGFPE in new long division asm code
kvn
parents: 7115
diff changeset
  7713
    __ jccb(Assembler::lessEqual, Lpos); // result is positive
69928525c55c 6997311: SIGFPE in new long division asm code
kvn
parents: 7115
diff changeset
  7714
69928525c55c 6997311: SIGFPE in new long division asm code
kvn
parents: 7115
diff changeset
  7715
    // Negative dividend.
69928525c55c 6997311: SIGFPE in new long division asm code
kvn
parents: 7115
diff changeset
  7716
    // convert value to positive to use unsigned division
69928525c55c 6997311: SIGFPE in new long division asm code
kvn
parents: 7115
diff changeset
  7717
    __ lneg($dst$$Register, $tmp2$$Register);
69928525c55c 6997311: SIGFPE in new long division asm code
kvn
parents: 7115
diff changeset
  7718
    __ divl($tmp$$Register);
7115
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  7719
    __ xchgl($dst$$Register, $tmp2$$Register);
7121
69928525c55c 6997311: SIGFPE in new long division asm code
kvn
parents: 7115
diff changeset
  7720
    __ divl($tmp$$Register);
69928525c55c 6997311: SIGFPE in new long division asm code
kvn
parents: 7115
diff changeset
  7721
    // revert result back to negative
69928525c55c 6997311: SIGFPE in new long division asm code
kvn
parents: 7115
diff changeset
  7722
    __ lneg($tmp2$$Register, $dst$$Register);
7115
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  7723
    __ jmpb(Ldone);
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  7724
7121
69928525c55c 6997311: SIGFPE in new long division asm code
kvn
parents: 7115
diff changeset
  7725
    __ bind(Lpos);
69928525c55c 6997311: SIGFPE in new long division asm code
kvn
parents: 7115
diff changeset
  7726
    __ divl($tmp$$Register); // Use unsigned division
69928525c55c 6997311: SIGFPE in new long division asm code
kvn
parents: 7115
diff changeset
  7727
    __ xchgl($dst$$Register, $tmp2$$Register);
69928525c55c 6997311: SIGFPE in new long division asm code
kvn
parents: 7115
diff changeset
  7728
    // Fallthrow for final divide, tmp2 has 32 bit hi result
69928525c55c 6997311: SIGFPE in new long division asm code
kvn
parents: 7115
diff changeset
  7729
7115
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  7730
    __ bind(Lfast);
7121
69928525c55c 6997311: SIGFPE in new long division asm code
kvn
parents: 7115
diff changeset
  7731
    // fast path: src is positive
69928525c55c 6997311: SIGFPE in new long division asm code
kvn
parents: 7115
diff changeset
  7732
    __ divl($tmp$$Register); // Use unsigned division
7115
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  7733
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  7734
    __ bind(Ldone);
7121
69928525c55c 6997311: SIGFPE in new long division asm code
kvn
parents: 7115
diff changeset
  7735
    __ movl(HIGH_FROM_LOW($dst$$Register),$tmp2$$Register);
7115
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  7736
    if (con < 0) {
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  7737
      __ lneg(HIGH_FROM_LOW($dst$$Register), $dst$$Register);
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  7738
    }
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  7739
  %}
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  7740
  ins_pipe( pipe_slow );
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  7741
%}
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  7742
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  7743
// Remainder Register Long (remainder fit into 32 bits)
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  7744
instruct modL_eReg_imm32( eADXRegL dst, immL32 imm, rRegI tmp, rRegI tmp2, eFlagsReg cr ) %{
7115
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  7745
  match(Set dst (ModL dst imm));
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  7746
  effect( TEMP tmp, TEMP tmp2, KILL cr );
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  7747
  ins_cost(1000);
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  7748
  format %{ "MOV    $tmp,abs($imm) # lrem EDX:EAX,$imm\n\t"
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  7749
            "CMP    $tmp,EDX\n\t"
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  7750
            "JA,s   fast\n\t"
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  7751
            "MOV    $tmp2,EAX\n\t"
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  7752
            "MOV    EAX,EDX\n\t"
7121
69928525c55c 6997311: SIGFPE in new long division asm code
kvn
parents: 7115
diff changeset
  7753
            "MOV    EDX,0\n\t"
69928525c55c 6997311: SIGFPE in new long division asm code
kvn
parents: 7115
diff changeset
  7754
            "JLE,s  pos\n\t"
69928525c55c 6997311: SIGFPE in new long division asm code
kvn
parents: 7115
diff changeset
  7755
            "LNEG   EAX : $tmp2\n\t"
69928525c55c 6997311: SIGFPE in new long division asm code
kvn
parents: 7115
diff changeset
  7756
            "DIV    $tmp # unsigned division\n\t"
69928525c55c 6997311: SIGFPE in new long division asm code
kvn
parents: 7115
diff changeset
  7757
            "MOV    EAX,$tmp2\n\t"
69928525c55c 6997311: SIGFPE in new long division asm code
kvn
parents: 7115
diff changeset
  7758
            "DIV    $tmp\n\t"
69928525c55c 6997311: SIGFPE in new long division asm code
kvn
parents: 7115
diff changeset
  7759
            "NEG    EDX\n\t"
69928525c55c 6997311: SIGFPE in new long division asm code
kvn
parents: 7115
diff changeset
  7760
            "JMP,s  done\n"
69928525c55c 6997311: SIGFPE in new long division asm code
kvn
parents: 7115
diff changeset
  7761
    "pos:\n\t"
69928525c55c 6997311: SIGFPE in new long division asm code
kvn
parents: 7115
diff changeset
  7762
            "DIV    $tmp\n\t"
7115
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  7763
            "MOV    EAX,$tmp2\n"
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  7764
    "fast:\n\t"
7121
69928525c55c 6997311: SIGFPE in new long division asm code
kvn
parents: 7115
diff changeset
  7765
            "DIV    $tmp\n"
69928525c55c 6997311: SIGFPE in new long division asm code
kvn
parents: 7115
diff changeset
  7766
    "done:\n\t"
7115
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  7767
            "MOV    EAX,EDX\n\t"
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  7768
            "SAR    EDX,31\n\t" %}
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  7769
  ins_encode %{
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  7770
    int con = (int)$imm$$constant;
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  7771
    assert(con != 0 && con != -1 && con != min_jint, "wrong divisor");
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  7772
    int pcon = (con > 0) ? con : -con;
7121
69928525c55c 6997311: SIGFPE in new long division asm code
kvn
parents: 7115
diff changeset
  7773
    Label  Lfast, Lpos, Ldone;
7115
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  7774
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  7775
    __ movl($tmp$$Register, pcon);
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  7776
    __ cmpl($tmp$$Register, HIGH_FROM_LOW($dst$$Register));
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  7777
    __ jccb(Assembler::above, Lfast); // src is positive and result fits into 32 bit
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  7778
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  7779
    __ movl($tmp2$$Register, $dst$$Register); // save
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  7780
    __ movl($dst$$Register, HIGH_FROM_LOW($dst$$Register));
7121
69928525c55c 6997311: SIGFPE in new long division asm code
kvn
parents: 7115
diff changeset
  7781
    __ movl(HIGH_FROM_LOW($dst$$Register),0); // preserve flags
69928525c55c 6997311: SIGFPE in new long division asm code
kvn
parents: 7115
diff changeset
  7782
    __ jccb(Assembler::lessEqual, Lpos); // result is positive
69928525c55c 6997311: SIGFPE in new long division asm code
kvn
parents: 7115
diff changeset
  7783
69928525c55c 6997311: SIGFPE in new long division asm code
kvn
parents: 7115
diff changeset
  7784
    // Negative dividend.
69928525c55c 6997311: SIGFPE in new long division asm code
kvn
parents: 7115
diff changeset
  7785
    // convert value to positive to use unsigned division
69928525c55c 6997311: SIGFPE in new long division asm code
kvn
parents: 7115
diff changeset
  7786
    __ lneg($dst$$Register, $tmp2$$Register);
69928525c55c 6997311: SIGFPE in new long division asm code
kvn
parents: 7115
diff changeset
  7787
    __ divl($tmp$$Register);
69928525c55c 6997311: SIGFPE in new long division asm code
kvn
parents: 7115
diff changeset
  7788
    __ movl($dst$$Register, $tmp2$$Register);
69928525c55c 6997311: SIGFPE in new long division asm code
kvn
parents: 7115
diff changeset
  7789
    __ divl($tmp$$Register);
69928525c55c 6997311: SIGFPE in new long division asm code
kvn
parents: 7115
diff changeset
  7790
    // revert remainder back to negative
69928525c55c 6997311: SIGFPE in new long division asm code
kvn
parents: 7115
diff changeset
  7791
    __ negl(HIGH_FROM_LOW($dst$$Register));
69928525c55c 6997311: SIGFPE in new long division asm code
kvn
parents: 7115
diff changeset
  7792
    __ jmpb(Ldone);
69928525c55c 6997311: SIGFPE in new long division asm code
kvn
parents: 7115
diff changeset
  7793
69928525c55c 6997311: SIGFPE in new long division asm code
kvn
parents: 7115
diff changeset
  7794
    __ bind(Lpos);
69928525c55c 6997311: SIGFPE in new long division asm code
kvn
parents: 7115
diff changeset
  7795
    __ divl($tmp$$Register);
7115
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  7796
    __ movl($dst$$Register, $tmp2$$Register);
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  7797
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  7798
    __ bind(Lfast);
7121
69928525c55c 6997311: SIGFPE in new long division asm code
kvn
parents: 7115
diff changeset
  7799
    // fast path: src is positive
69928525c55c 6997311: SIGFPE in new long division asm code
kvn
parents: 7115
diff changeset
  7800
    __ divl($tmp$$Register);
69928525c55c 6997311: SIGFPE in new long division asm code
kvn
parents: 7115
diff changeset
  7801
69928525c55c 6997311: SIGFPE in new long division asm code
kvn
parents: 7115
diff changeset
  7802
    __ bind(Ldone);
7115
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  7803
    __ movl($dst$$Register, HIGH_FROM_LOW($dst$$Register));
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  7804
    __ sarl(HIGH_FROM_LOW($dst$$Register), 31); // result sign
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  7805
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  7806
  %}
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  7807
  ins_pipe( pipe_slow );
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  7808
%}
32300e243300 6987135: Performance regression on Intel platform with 32-bits edition between 6u13 and 6u14.
kvn
parents: 6418
diff changeset
  7809
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7810
// Integer Shift Instructions
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7811
// Shift Left by one
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  7812
instruct shlI_eReg_1(rRegI dst, immI1 shift, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7813
  match(Set dst (LShiftI dst shift));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7814
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7815
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7816
  size(2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7817
  format %{ "SHL    $dst,$shift" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7818
  opcode(0xD1, 0x4);  /* D1 /4 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7819
  ins_encode( OpcP, RegOpc( dst ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7820
  ins_pipe( ialu_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7821
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7822
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7823
// Shift Left by 8-bit immediate
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  7824
instruct salI_eReg_imm(rRegI dst, immI8 shift, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7825
  match(Set dst (LShiftI dst shift));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7826
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7827
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7828
  size(3);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7829
  format %{ "SHL    $dst,$shift" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7830
  opcode(0xC1, 0x4);  /* C1 /4 ib */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7831
  ins_encode( RegOpcImm( dst, shift) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7832
  ins_pipe( ialu_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7833
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7834
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7835
// Shift Left by variable
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  7836
instruct salI_eReg_CL(rRegI dst, eCXRegI shift, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7837
  match(Set dst (LShiftI dst shift));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7838
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7839
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7840
  size(2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7841
  format %{ "SHL    $dst,$shift" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7842
  opcode(0xD3, 0x4);  /* D3 /4 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7843
  ins_encode( OpcP, RegOpc( dst ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7844
  ins_pipe( ialu_reg_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7845
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7846
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7847
// Arithmetic shift right by one
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  7848
instruct sarI_eReg_1(rRegI dst, immI1 shift, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7849
  match(Set dst (RShiftI dst shift));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7850
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7851
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7852
  size(2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7853
  format %{ "SAR    $dst,$shift" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7854
  opcode(0xD1, 0x7);  /* D1 /7 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7855
  ins_encode( OpcP, RegOpc( dst ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7856
  ins_pipe( ialu_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7857
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7858
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7859
// Arithmetic shift right by one
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7860
instruct sarI_mem_1(memory dst, immI1 shift, eFlagsReg cr) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7861
  match(Set dst (StoreI dst (RShiftI (LoadI dst) shift)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7862
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7863
  format %{ "SAR    $dst,$shift" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7864
  opcode(0xD1, 0x7);  /* D1 /7 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7865
  ins_encode( OpcP, RMopc_Mem(secondary,dst) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7866
  ins_pipe( ialu_mem_imm );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7867
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7868
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7869
// Arithmetic Shift Right by 8-bit immediate
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  7870
instruct sarI_eReg_imm(rRegI dst, immI8 shift, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7871
  match(Set dst (RShiftI dst shift));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7872
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7873
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7874
  size(3);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7875
  format %{ "SAR    $dst,$shift" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7876
  opcode(0xC1, 0x7);  /* C1 /7 ib */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7877
  ins_encode( RegOpcImm( dst, shift ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7878
  ins_pipe( ialu_mem_imm );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7879
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7880
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7881
// Arithmetic Shift Right by 8-bit immediate
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7882
instruct sarI_mem_imm(memory dst, immI8 shift, eFlagsReg cr) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7883
  match(Set dst (StoreI dst (RShiftI (LoadI dst) shift)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7884
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7885
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7886
  format %{ "SAR    $dst,$shift" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7887
  opcode(0xC1, 0x7);  /* C1 /7 ib */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7888
  ins_encode( OpcP, RMopc_Mem(secondary, dst ), Con8or32( shift ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7889
  ins_pipe( ialu_mem_imm );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7890
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7891
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7892
// Arithmetic Shift Right by variable
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  7893
instruct sarI_eReg_CL(rRegI dst, eCXRegI shift, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7894
  match(Set dst (RShiftI dst shift));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7895
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7896
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7897
  size(2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7898
  format %{ "SAR    $dst,$shift" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7899
  opcode(0xD3, 0x7);  /* D3 /7 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7900
  ins_encode( OpcP, RegOpc( dst ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7901
  ins_pipe( ialu_reg_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7902
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7903
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7904
// Logical shift right by one
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  7905
instruct shrI_eReg_1(rRegI dst, immI1 shift, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7906
  match(Set dst (URShiftI dst shift));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7907
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7908
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7909
  size(2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7910
  format %{ "SHR    $dst,$shift" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7911
  opcode(0xD1, 0x5);  /* D1 /5 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7912
  ins_encode( OpcP, RegOpc( dst ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7913
  ins_pipe( ialu_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7914
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7915
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7916
// Logical Shift Right by 8-bit immediate
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  7917
instruct shrI_eReg_imm(rRegI dst, immI8 shift, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7918
  match(Set dst (URShiftI dst shift));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7919
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7920
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7921
  size(3);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7922
  format %{ "SHR    $dst,$shift" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7923
  opcode(0xC1, 0x5);  /* C1 /5 ib */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7924
  ins_encode( RegOpcImm( dst, shift) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7925
  ins_pipe( ialu_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7926
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7927
1500
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
  7928
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7929
// Logical Shift Right by 24, followed by Arithmetic Shift Left by 24.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7930
// This idiom is used by the compiler for the i2b bytecode.
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  7931
instruct i2b(rRegI dst, xRegI src, immI_24 twentyfour) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7932
  match(Set dst (RShiftI (LShiftI src twentyfour) twentyfour));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7933
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7934
  size(3);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7935
  format %{ "MOVSX  $dst,$src :8" %}
2872
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  7936
  ins_encode %{
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  7937
    __ movsbl($dst$$Register, $src$$Register);
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  7938
  %}
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  7939
  ins_pipe(ialu_reg_reg);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7940
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7941
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7942
// Logical Shift Right by 16, followed by Arithmetic Shift Left by 16.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7943
// This idiom is used by the compiler the i2s bytecode.
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  7944
instruct i2s(rRegI dst, xRegI src, immI_16 sixteen) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7945
  match(Set dst (RShiftI (LShiftI src sixteen) sixteen));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7946
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7947
  size(3);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7948
  format %{ "MOVSX  $dst,$src :16" %}
2872
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  7949
  ins_encode %{
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  7950
    __ movswl($dst$$Register, $src$$Register);
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  7951
  %}
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  7952
  ins_pipe(ialu_reg_reg);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7953
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7954
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7955
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7956
// Logical Shift Right by variable
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  7957
instruct shrI_eReg_CL(rRegI dst, eCXRegI shift, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7958
  match(Set dst (URShiftI dst shift));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7959
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7960
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7961
  size(2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7962
  format %{ "SHR    $dst,$shift" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7963
  opcode(0xD3, 0x5);  /* D3 /5 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7964
  ins_encode( OpcP, RegOpc( dst ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7965
  ins_pipe( ialu_reg_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7966
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7967
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7968
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7969
//----------Logical Instructions-----------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7970
//----------Integer Logical Instructions---------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7971
// And Instructions
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7972
// And Register with Register
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  7973
instruct andI_eReg(rRegI dst, rRegI src, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7974
  match(Set dst (AndI dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7975
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7976
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7977
  size(2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7978
  format %{ "AND    $dst,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7979
  opcode(0x23);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7980
  ins_encode( OpcP, RegReg( dst, src) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7981
  ins_pipe( ialu_reg_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7982
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7983
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7984
// And Register with Immediate
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  7985
instruct andI_eReg_imm(rRegI dst, immI src, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7986
  match(Set dst (AndI dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7987
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7988
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7989
  format %{ "AND    $dst,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7990
  opcode(0x81,0x04);  /* Opcode 81 /4 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7991
  // ins_encode( RegImm( dst, src) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7992
  ins_encode( OpcSErm( dst, src ), Con8or32( src ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7993
  ins_pipe( ialu_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7994
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7995
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7996
// And Register with Memory
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  7997
instruct andI_eReg_mem(rRegI dst, memory src, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7998
  match(Set dst (AndI dst (LoadI src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7999
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8000
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8001
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8002
  format %{ "AND    $dst,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8003
  opcode(0x23);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8004
  ins_encode( OpcP, RegMem( dst, src) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8005
  ins_pipe( ialu_reg_mem );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8006
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8007
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8008
// And Memory with Register
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  8009
instruct andI_mem_eReg(memory dst, rRegI src, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8010
  match(Set dst (StoreI dst (AndI (LoadI dst) src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8011
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8012
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8013
  ins_cost(150);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8014
  format %{ "AND    $dst,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8015
  opcode(0x21);  /* Opcode 21 /r */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8016
  ins_encode( OpcP, RegMem( src, dst ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8017
  ins_pipe( ialu_mem_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8018
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8019
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8020
// And Memory with Immediate
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8021
instruct andI_mem_imm(memory dst, immI src, eFlagsReg cr) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8022
  match(Set dst (StoreI dst (AndI (LoadI dst) src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8023
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8024
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8025
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8026
  format %{ "AND    $dst,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8027
  opcode(0x81, 0x4);  /* Opcode 81 /4 id */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8028
  // ins_encode( MemImm( dst, src) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8029
  ins_encode( OpcSE( src ), RMopc_Mem(secondary, dst ), Con8or32( src ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8030
  ins_pipe( ialu_mem_imm );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8031
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8032
23220
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8033
// BMI1 instructions
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8034
instruct andnI_rReg_rReg_rReg(rRegI dst, rRegI src1, rRegI src2, immI_M1 minus_1, eFlagsReg cr) %{
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8035
  match(Set dst (AndI (XorI src1 minus_1) src2));
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8036
  predicate(UseBMI1Instructions);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8037
  effect(KILL cr);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8038
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8039
  format %{ "ANDNL  $dst, $src1, $src2" %}
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8040
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8041
  ins_encode %{
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8042
    __ andnl($dst$$Register, $src1$$Register, $src2$$Register);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8043
  %}
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8044
  ins_pipe(ialu_reg);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8045
%}
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8046
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8047
instruct andnI_rReg_rReg_mem(rRegI dst, rRegI src1, memory src2, immI_M1 minus_1, eFlagsReg cr) %{
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8048
  match(Set dst (AndI (XorI src1 minus_1) (LoadI src2) ));
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8049
  predicate(UseBMI1Instructions);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8050
  effect(KILL cr);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8051
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8052
  ins_cost(125);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8053
  format %{ "ANDNL  $dst, $src1, $src2" %}
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8054
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8055
  ins_encode %{
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8056
    __ andnl($dst$$Register, $src1$$Register, $src2$$Address);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8057
  %}
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8058
  ins_pipe(ialu_reg_mem);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8059
%}
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8060
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8061
instruct blsiI_rReg_rReg(rRegI dst, rRegI src, immI0 imm_zero, eFlagsReg cr) %{
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8062
  match(Set dst (AndI (SubI imm_zero src) src));
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8063
  predicate(UseBMI1Instructions);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8064
  effect(KILL cr);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8065
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8066
  format %{ "BLSIL  $dst, $src" %}
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8067
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8068
  ins_encode %{
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8069
    __ blsil($dst$$Register, $src$$Register);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8070
  %}
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8071
  ins_pipe(ialu_reg);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8072
%}
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8073
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8074
instruct blsiI_rReg_mem(rRegI dst, memory src, immI0 imm_zero, eFlagsReg cr) %{
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8075
  match(Set dst (AndI (SubI imm_zero (LoadI src) ) (LoadI src) ));
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8076
  predicate(UseBMI1Instructions);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8077
  effect(KILL cr);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8078
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8079
  ins_cost(125);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8080
  format %{ "BLSIL  $dst, $src" %}
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8081
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8082
  ins_encode %{
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8083
    __ blsil($dst$$Register, $src$$Address);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8084
  %}
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8085
  ins_pipe(ialu_reg_mem);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8086
%}
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8087
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8088
instruct blsmskI_rReg_rReg(rRegI dst, rRegI src, immI_M1 minus_1, eFlagsReg cr)
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8089
%{
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8090
  match(Set dst (XorI (AddI src minus_1) src));
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8091
  predicate(UseBMI1Instructions);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8092
  effect(KILL cr);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8093
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8094
  format %{ "BLSMSKL $dst, $src" %}
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8095
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8096
  ins_encode %{
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8097
    __ blsmskl($dst$$Register, $src$$Register);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8098
  %}
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8099
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8100
  ins_pipe(ialu_reg);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8101
%}
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8102
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8103
instruct blsmskI_rReg_mem(rRegI dst, memory src, immI_M1 minus_1, eFlagsReg cr)
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8104
%{
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8105
  match(Set dst (XorI (AddI (LoadI src) minus_1) (LoadI src) ));
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8106
  predicate(UseBMI1Instructions);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8107
  effect(KILL cr);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8108
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8109
  ins_cost(125);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8110
  format %{ "BLSMSKL $dst, $src" %}
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8111
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8112
  ins_encode %{
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8113
    __ blsmskl($dst$$Register, $src$$Address);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8114
  %}
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8115
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8116
  ins_pipe(ialu_reg_mem);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8117
%}
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8118
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8119
instruct blsrI_rReg_rReg(rRegI dst, rRegI src, immI_M1 minus_1, eFlagsReg cr)
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8120
%{
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8121
  match(Set dst (AndI (AddI src minus_1) src) );
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8122
  predicate(UseBMI1Instructions);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8123
  effect(KILL cr);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8124
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8125
  format %{ "BLSRL  $dst, $src" %}
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8126
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8127
  ins_encode %{
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8128
    __ blsrl($dst$$Register, $src$$Register);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8129
  %}
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8130
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8131
  ins_pipe(ialu_reg);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8132
%}
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8133
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8134
instruct blsrI_rReg_mem(rRegI dst, memory src, immI_M1 minus_1, eFlagsReg cr)
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8135
%{
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8136
  match(Set dst (AndI (AddI (LoadI src) minus_1) (LoadI src) ));
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8137
  predicate(UseBMI1Instructions);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8138
  effect(KILL cr);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8139
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8140
  ins_cost(125);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8141
  format %{ "BLSRL  $dst, $src" %}
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8142
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8143
  ins_encode %{
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8144
    __ blsrl($dst$$Register, $src$$Address);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8145
  %}
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8146
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8147
  ins_pipe(ialu_reg_mem);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8148
%}
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8149
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8150
// Or Instructions
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8151
// Or Register with Register
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  8152
instruct orI_eReg(rRegI dst, rRegI src, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8153
  match(Set dst (OrI dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8154
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8155
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8156
  size(2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8157
  format %{ "OR     $dst,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8158
  opcode(0x0B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8159
  ins_encode( OpcP, RegReg( dst, src) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8160
  ins_pipe( ialu_reg_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8161
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8162
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  8163
instruct orI_eReg_castP2X(rRegI dst, eRegP src, eFlagsReg cr) %{
1500
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
  8164
  match(Set dst (OrI dst (CastP2X src)));
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
  8165
  effect(KILL cr);
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
  8166
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
  8167
  size(2);
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
  8168
  format %{ "OR     $dst,$src" %}
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
  8169
  opcode(0x0B);
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
  8170
  ins_encode( OpcP, RegReg( dst, src) );
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
  8171
  ins_pipe( ialu_reg_reg );
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
  8172
%}
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
  8173
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
  8174
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8175
// Or Register with Immediate
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  8176
instruct orI_eReg_imm(rRegI dst, immI src, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8177
  match(Set dst (OrI dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8178
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8179
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8180
  format %{ "OR     $dst,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8181
  opcode(0x81,0x01);  /* Opcode 81 /1 id */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8182
  // ins_encode( RegImm( dst, src) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8183
  ins_encode( OpcSErm( dst, src ), Con8or32( src ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8184
  ins_pipe( ialu_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8185
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8186
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8187
// Or Register with Memory
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  8188
instruct orI_eReg_mem(rRegI dst, memory src, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8189
  match(Set dst (OrI dst (LoadI src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8190
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8191
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8192
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8193
  format %{ "OR     $dst,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8194
  opcode(0x0B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8195
  ins_encode( OpcP, RegMem( dst, src) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8196
  ins_pipe( ialu_reg_mem );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8197
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8198
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8199
// Or Memory with Register
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  8200
instruct orI_mem_eReg(memory dst, rRegI src, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8201
  match(Set dst (StoreI dst (OrI (LoadI dst) src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8202
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8203
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8204
  ins_cost(150);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8205
  format %{ "OR     $dst,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8206
  opcode(0x09);  /* Opcode 09 /r */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8207
  ins_encode( OpcP, RegMem( src, dst ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8208
  ins_pipe( ialu_mem_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8209
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8210
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8211
// Or Memory with Immediate
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8212
instruct orI_mem_imm(memory dst, immI src, eFlagsReg cr) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8213
  match(Set dst (StoreI dst (OrI (LoadI dst) src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8214
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8215
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8216
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8217
  format %{ "OR     $dst,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8218
  opcode(0x81,0x1);  /* Opcode 81 /1 id */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8219
  // ins_encode( MemImm( dst, src) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8220
  ins_encode( OpcSE( src ), RMopc_Mem(secondary, dst ), Con8or32( src ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8221
  ins_pipe( ialu_mem_imm );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8222
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8223
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8224
// ROL/ROR
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8225
// ROL expand
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  8226
instruct rolI_eReg_imm1(rRegI dst, immI1 shift, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8227
  effect(USE_DEF dst, USE shift, KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8228
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8229
  format %{ "ROL    $dst, $shift" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8230
  opcode(0xD1, 0x0); /* Opcode D1 /0 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8231
  ins_encode( OpcP, RegOpc( dst ));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8232
  ins_pipe( ialu_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8233
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8234
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  8235
instruct rolI_eReg_imm8(rRegI dst, immI8 shift, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8236
  effect(USE_DEF dst, USE shift, KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8237
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8238
  format %{ "ROL    $dst, $shift" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8239
  opcode(0xC1, 0x0); /*Opcode /C1  /0  */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8240
  ins_encode( RegOpcImm(dst, shift) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8241
  ins_pipe(ialu_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8242
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8243
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8244
instruct rolI_eReg_CL(ncxRegI dst, eCXRegI shift, eFlagsReg cr) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8245
  effect(USE_DEF dst, USE shift, KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8246
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8247
  format %{ "ROL    $dst, $shift" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8248
  opcode(0xD3, 0x0);    /* Opcode D3 /0 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8249
  ins_encode(OpcP, RegOpc(dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8250
  ins_pipe( ialu_reg_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8251
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8252
// end of ROL expand
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8253
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8254
// ROL 32bit by one once
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  8255
instruct rolI_eReg_i1(rRegI dst, immI1 lshift, immI_M1 rshift, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8256
  match(Set dst ( OrI (LShiftI dst lshift) (URShiftI dst rshift)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8257
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8258
  expand %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8259
    rolI_eReg_imm1(dst, lshift, cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8260
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8261
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8262
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8263
// ROL 32bit var by imm8 once
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  8264
instruct rolI_eReg_i8(rRegI dst, immI8 lshift, immI8 rshift, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8265
  predicate(  0 == ((n->in(1)->in(2)->get_int() + n->in(2)->in(2)->get_int()) & 0x1f));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8266
  match(Set dst ( OrI (LShiftI dst lshift) (URShiftI dst rshift)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8267
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8268
  expand %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8269
    rolI_eReg_imm8(dst, lshift, cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8270
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8271
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8272
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8273
// ROL 32bit var by var once
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8274
instruct rolI_eReg_Var_C0(ncxRegI dst, eCXRegI shift, immI0 zero, eFlagsReg cr) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8275
  match(Set dst ( OrI (LShiftI dst shift) (URShiftI dst (SubI zero shift))));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8276
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8277
  expand %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8278
    rolI_eReg_CL(dst, shift, cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8279
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8280
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8281
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8282
// ROL 32bit var by var once
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8283
instruct rolI_eReg_Var_C32(ncxRegI dst, eCXRegI shift, immI_32 c32, eFlagsReg cr) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8284
  match(Set dst ( OrI (LShiftI dst shift) (URShiftI dst (SubI c32 shift))));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8285
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8286
  expand %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8287
    rolI_eReg_CL(dst, shift, cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8288
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8289
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8290
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8291
// ROR expand
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  8292
instruct rorI_eReg_imm1(rRegI dst, immI1 shift, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8293
  effect(USE_DEF dst, USE shift, KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8294
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8295
  format %{ "ROR    $dst, $shift" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8296
  opcode(0xD1,0x1);  /* Opcode D1 /1 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8297
  ins_encode( OpcP, RegOpc( dst ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8298
  ins_pipe( ialu_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8299
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8300
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  8301
instruct rorI_eReg_imm8(rRegI dst, immI8 shift, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8302
  effect (USE_DEF dst, USE shift, KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8303
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8304
  format %{ "ROR    $dst, $shift" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8305
  opcode(0xC1, 0x1); /* Opcode /C1 /1 ib */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8306
  ins_encode( RegOpcImm(dst, shift) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8307
  ins_pipe( ialu_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8308
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8309
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8310
instruct rorI_eReg_CL(ncxRegI dst, eCXRegI shift, eFlagsReg cr)%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8311
  effect(USE_DEF dst, USE shift, KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8312
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8313
  format %{ "ROR    $dst, $shift" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8314
  opcode(0xD3, 0x1);    /* Opcode D3 /1 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8315
  ins_encode(OpcP, RegOpc(dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8316
  ins_pipe( ialu_reg_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8317
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8318
// end of ROR expand
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8319
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8320
// ROR right once
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  8321
instruct rorI_eReg_i1(rRegI dst, immI1 rshift, immI_M1 lshift, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8322
  match(Set dst ( OrI (URShiftI dst rshift) (LShiftI dst lshift)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8323
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8324
  expand %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8325
    rorI_eReg_imm1(dst, rshift, cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8326
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8327
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8328
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8329
// ROR 32bit by immI8 once
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  8330
instruct rorI_eReg_i8(rRegI dst, immI8 rshift, immI8 lshift, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8331
  predicate(  0 == ((n->in(1)->in(2)->get_int() + n->in(2)->in(2)->get_int()) & 0x1f));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8332
  match(Set dst ( OrI (URShiftI dst rshift) (LShiftI dst lshift)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8333
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8334
  expand %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8335
    rorI_eReg_imm8(dst, rshift, cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8336
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8337
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8338
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8339
// ROR 32bit var by var once
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8340
instruct rorI_eReg_Var_C0(ncxRegI dst, eCXRegI shift, immI0 zero, eFlagsReg cr) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8341
  match(Set dst ( OrI (URShiftI dst shift) (LShiftI dst (SubI zero shift))));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8342
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8343
  expand %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8344
    rorI_eReg_CL(dst, shift, cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8345
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8346
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8347
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8348
// ROR 32bit var by var once
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8349
instruct rorI_eReg_Var_C32(ncxRegI dst, eCXRegI shift, immI_32 c32, eFlagsReg cr) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8350
  match(Set dst ( OrI (URShiftI dst shift) (LShiftI dst (SubI c32 shift))));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8351
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8352
  expand %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8353
    rorI_eReg_CL(dst, shift, cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8354
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8355
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8356
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8357
// Xor Instructions
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8358
// Xor Register with Register
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  8359
instruct xorI_eReg(rRegI dst, rRegI src, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8360
  match(Set dst (XorI dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8361
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8362
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8363
  size(2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8364
  format %{ "XOR    $dst,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8365
  opcode(0x33);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8366
  ins_encode( OpcP, RegReg( dst, src) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8367
  ins_pipe( ialu_reg_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8368
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8369
1435
72a8da703ff0 6752257: Use NOT instead of XOR -1 on x86
rasbold
parents: 1066
diff changeset
  8370
// Xor Register with Immediate -1
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  8371
instruct xorI_eReg_im1(rRegI dst, immI_M1 imm) %{
30624
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
  8372
  match(Set dst (XorI dst imm));
1435
72a8da703ff0 6752257: Use NOT instead of XOR -1 on x86
rasbold
parents: 1066
diff changeset
  8373
72a8da703ff0 6752257: Use NOT instead of XOR -1 on x86
rasbold
parents: 1066
diff changeset
  8374
  size(2);
30624
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
  8375
  format %{ "NOT    $dst" %}
1435
72a8da703ff0 6752257: Use NOT instead of XOR -1 on x86
rasbold
parents: 1066
diff changeset
  8376
  ins_encode %{
72a8da703ff0 6752257: Use NOT instead of XOR -1 on x86
rasbold
parents: 1066
diff changeset
  8377
     __ notl($dst$$Register);
72a8da703ff0 6752257: Use NOT instead of XOR -1 on x86
rasbold
parents: 1066
diff changeset
  8378
  %}
72a8da703ff0 6752257: Use NOT instead of XOR -1 on x86
rasbold
parents: 1066
diff changeset
  8379
  ins_pipe( ialu_reg );
72a8da703ff0 6752257: Use NOT instead of XOR -1 on x86
rasbold
parents: 1066
diff changeset
  8380
%}
72a8da703ff0 6752257: Use NOT instead of XOR -1 on x86
rasbold
parents: 1066
diff changeset
  8381
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8382
// Xor Register with Immediate
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  8383
instruct xorI_eReg_imm(rRegI dst, immI src, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8384
  match(Set dst (XorI dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8385
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8386
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8387
  format %{ "XOR    $dst,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8388
  opcode(0x81,0x06);  /* Opcode 81 /6 id */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8389
  // ins_encode( RegImm( dst, src) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8390
  ins_encode( OpcSErm( dst, src ), Con8or32( src ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8391
  ins_pipe( ialu_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8392
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8393
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8394
// Xor Register with Memory
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  8395
instruct xorI_eReg_mem(rRegI dst, memory src, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8396
  match(Set dst (XorI dst (LoadI src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8397
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8398
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8399
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8400
  format %{ "XOR    $dst,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8401
  opcode(0x33);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8402
  ins_encode( OpcP, RegMem(dst, src) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8403
  ins_pipe( ialu_reg_mem );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8404
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8405
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8406
// Xor Memory with Register
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  8407
instruct xorI_mem_eReg(memory dst, rRegI src, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8408
  match(Set dst (StoreI dst (XorI (LoadI dst) src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8409
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8410
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8411
  ins_cost(150);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8412
  format %{ "XOR    $dst,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8413
  opcode(0x31);  /* Opcode 31 /r */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8414
  ins_encode( OpcP, RegMem( src, dst ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8415
  ins_pipe( ialu_mem_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8416
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8417
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8418
// Xor Memory with Immediate
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8419
instruct xorI_mem_imm(memory dst, immI src, eFlagsReg cr) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8420
  match(Set dst (StoreI dst (XorI (LoadI dst) src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8421
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8422
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8423
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8424
  format %{ "XOR    $dst,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8425
  opcode(0x81,0x6);  /* Opcode 81 /6 id */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8426
  ins_encode( OpcSE( src ), RMopc_Mem(secondary, dst ), Con8or32( src ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8427
  ins_pipe( ialu_mem_imm );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8428
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8429
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8430
//----------Convert Int to Boolean---------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8431
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  8432
instruct movI_nocopy(rRegI dst, rRegI src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8433
  effect( DEF dst, USE src );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8434
  format %{ "MOV    $dst,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8435
  ins_encode( enc_Copy( dst, src) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8436
  ins_pipe( ialu_reg_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8437
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8438
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  8439
instruct ci2b( rRegI dst, rRegI src, eFlagsReg cr ) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8440
  effect( USE_DEF dst, USE src, KILL cr );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8441
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8442
  size(4);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8443
  format %{ "NEG    $dst\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8444
            "ADC    $dst,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8445
  ins_encode( neg_reg(dst),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8446
              OpcRegReg(0x13,dst,src) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8447
  ins_pipe( ialu_reg_reg_long );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8448
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8449
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  8450
instruct convI2B( rRegI dst, rRegI src, eFlagsReg cr ) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8451
  match(Set dst (Conv2B src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8452
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8453
  expand %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8454
    movI_nocopy(dst,src);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8455
    ci2b(dst,src,cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8456
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8457
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8458
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  8459
instruct movP_nocopy(rRegI dst, eRegP src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8460
  effect( DEF dst, USE src );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8461
  format %{ "MOV    $dst,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8462
  ins_encode( enc_Copy( dst, src) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8463
  ins_pipe( ialu_reg_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8464
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8465
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  8466
instruct cp2b( rRegI dst, eRegP src, eFlagsReg cr ) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8467
  effect( USE_DEF dst, USE src, KILL cr );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8468
  format %{ "NEG    $dst\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8469
            "ADC    $dst,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8470
  ins_encode( neg_reg(dst),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8471
              OpcRegReg(0x13,dst,src) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8472
  ins_pipe( ialu_reg_reg_long );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8473
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8474
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  8475
instruct convP2B( rRegI dst, eRegP src, eFlagsReg cr ) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8476
  match(Set dst (Conv2B src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8477
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8478
  expand %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8479
    movP_nocopy(dst,src);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8480
    cp2b(dst,src,cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8481
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8482
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8483
17008
fe66415573bf 6443505: Ideal() function for CmpLTMask
drchase
parents: 16624
diff changeset
  8484
instruct cmpLTMask(eCXRegI dst, ncxRegI p, ncxRegI q, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8485
  match(Set dst (CmpLTMask p q));
17008
fe66415573bf 6443505: Ideal() function for CmpLTMask
drchase
parents: 16624
diff changeset
  8486
  effect(KILL cr);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8487
  ins_cost(400);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8488
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8489
  // SETlt can only use low byte of EAX,EBX, ECX, or EDX as destination
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8490
  format %{ "XOR    $dst,$dst\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8491
            "CMP    $p,$q\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8492
            "SETlt  $dst\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8493
            "NEG    $dst" %}
17008
fe66415573bf 6443505: Ideal() function for CmpLTMask
drchase
parents: 16624
diff changeset
  8494
  ins_encode %{
fe66415573bf 6443505: Ideal() function for CmpLTMask
drchase
parents: 16624
diff changeset
  8495
    Register Rp = $p$$Register;
fe66415573bf 6443505: Ideal() function for CmpLTMask
drchase
parents: 16624
diff changeset
  8496
    Register Rq = $q$$Register;
fe66415573bf 6443505: Ideal() function for CmpLTMask
drchase
parents: 16624
diff changeset
  8497
    Register Rd = $dst$$Register;
fe66415573bf 6443505: Ideal() function for CmpLTMask
drchase
parents: 16624
diff changeset
  8498
    Label done;
fe66415573bf 6443505: Ideal() function for CmpLTMask
drchase
parents: 16624
diff changeset
  8499
    __ xorl(Rd, Rd);
fe66415573bf 6443505: Ideal() function for CmpLTMask
drchase
parents: 16624
diff changeset
  8500
    __ cmpl(Rp, Rq);
fe66415573bf 6443505: Ideal() function for CmpLTMask
drchase
parents: 16624
diff changeset
  8501
    __ setb(Assembler::less, Rd);
fe66415573bf 6443505: Ideal() function for CmpLTMask
drchase
parents: 16624
diff changeset
  8502
    __ negl(Rd);
fe66415573bf 6443505: Ideal() function for CmpLTMask
drchase
parents: 16624
diff changeset
  8503
  %}
fe66415573bf 6443505: Ideal() function for CmpLTMask
drchase
parents: 16624
diff changeset
  8504
fe66415573bf 6443505: Ideal() function for CmpLTMask
drchase
parents: 16624
diff changeset
  8505
  ins_pipe(pipe_slow);
fe66415573bf 6443505: Ideal() function for CmpLTMask
drchase
parents: 16624
diff changeset
  8506
%}
fe66415573bf 6443505: Ideal() function for CmpLTMask
drchase
parents: 16624
diff changeset
  8507
fe66415573bf 6443505: Ideal() function for CmpLTMask
drchase
parents: 16624
diff changeset
  8508
instruct cmpLTMask0(rRegI dst, immI0 zero, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8509
  match(Set dst (CmpLTMask dst zero));
17008
fe66415573bf 6443505: Ideal() function for CmpLTMask
drchase
parents: 16624
diff changeset
  8510
  effect(DEF dst, KILL cr);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8511
  ins_cost(100);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8512
17008
fe66415573bf 6443505: Ideal() function for CmpLTMask
drchase
parents: 16624
diff changeset
  8513
  format %{ "SAR    $dst,31\t# cmpLTMask0" %}
fe66415573bf 6443505: Ideal() function for CmpLTMask
drchase
parents: 16624
diff changeset
  8514
  ins_encode %{
fe66415573bf 6443505: Ideal() function for CmpLTMask
drchase
parents: 16624
diff changeset
  8515
  __ sarl($dst$$Register, 31);
fe66415573bf 6443505: Ideal() function for CmpLTMask
drchase
parents: 16624
diff changeset
  8516
  %}
fe66415573bf 6443505: Ideal() function for CmpLTMask
drchase
parents: 16624
diff changeset
  8517
  ins_pipe(ialu_reg);
fe66415573bf 6443505: Ideal() function for CmpLTMask
drchase
parents: 16624
diff changeset
  8518
%}
fe66415573bf 6443505: Ideal() function for CmpLTMask
drchase
parents: 16624
diff changeset
  8519
fe66415573bf 6443505: Ideal() function for CmpLTMask
drchase
parents: 16624
diff changeset
  8520
/* better to save a register than avoid a branch */
fe66415573bf 6443505: Ideal() function for CmpLTMask
drchase
parents: 16624
diff changeset
  8521
instruct cadd_cmpLTMask(rRegI p, rRegI q, rRegI y, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8522
  match(Set p (AddI (AndI (CmpLTMask p q) y) (SubI p q)));
17008
fe66415573bf 6443505: Ideal() function for CmpLTMask
drchase
parents: 16624
diff changeset
  8523
  effect(KILL cr);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8524
  ins_cost(400);
17008
fe66415573bf 6443505: Ideal() function for CmpLTMask
drchase
parents: 16624
diff changeset
  8525
  format %{ "SUB    $p,$q\t# cadd_cmpLTMask\n\t"
fe66415573bf 6443505: Ideal() function for CmpLTMask
drchase
parents: 16624
diff changeset
  8526
            "JGE    done\n\t"
fe66415573bf 6443505: Ideal() function for CmpLTMask
drchase
parents: 16624
diff changeset
  8527
            "ADD    $p,$y\n"
fe66415573bf 6443505: Ideal() function for CmpLTMask
drchase
parents: 16624
diff changeset
  8528
            "done:  " %}
fe66415573bf 6443505: Ideal() function for CmpLTMask
drchase
parents: 16624
diff changeset
  8529
  ins_encode %{
fe66415573bf 6443505: Ideal() function for CmpLTMask
drchase
parents: 16624
diff changeset
  8530
    Register Rp = $p$$Register;
fe66415573bf 6443505: Ideal() function for CmpLTMask
drchase
parents: 16624
diff changeset
  8531
    Register Rq = $q$$Register;
fe66415573bf 6443505: Ideal() function for CmpLTMask
drchase
parents: 16624
diff changeset
  8532
    Register Ry = $y$$Register;
fe66415573bf 6443505: Ideal() function for CmpLTMask
drchase
parents: 16624
diff changeset
  8533
    Label done;
fe66415573bf 6443505: Ideal() function for CmpLTMask
drchase
parents: 16624
diff changeset
  8534
    __ subl(Rp, Rq);
fe66415573bf 6443505: Ideal() function for CmpLTMask
drchase
parents: 16624
diff changeset
  8535
    __ jccb(Assembler::greaterEqual, done);
fe66415573bf 6443505: Ideal() function for CmpLTMask
drchase
parents: 16624
diff changeset
  8536
    __ addl(Rp, Ry);
fe66415573bf 6443505: Ideal() function for CmpLTMask
drchase
parents: 16624
diff changeset
  8537
    __ bind(done);
fe66415573bf 6443505: Ideal() function for CmpLTMask
drchase
parents: 16624
diff changeset
  8538
  %}
fe66415573bf 6443505: Ideal() function for CmpLTMask
drchase
parents: 16624
diff changeset
  8539
fe66415573bf 6443505: Ideal() function for CmpLTMask
drchase
parents: 16624
diff changeset
  8540
  ins_pipe(pipe_cmplt);
fe66415573bf 6443505: Ideal() function for CmpLTMask
drchase
parents: 16624
diff changeset
  8541
%}
fe66415573bf 6443505: Ideal() function for CmpLTMask
drchase
parents: 16624
diff changeset
  8542
fe66415573bf 6443505: Ideal() function for CmpLTMask
drchase
parents: 16624
diff changeset
  8543
/* better to save a register than avoid a branch */
fe66415573bf 6443505: Ideal() function for CmpLTMask
drchase
parents: 16624
diff changeset
  8544
instruct and_cmpLTMask(rRegI p, rRegI q, rRegI y, eFlagsReg cr) %{
fe66415573bf 6443505: Ideal() function for CmpLTMask
drchase
parents: 16624
diff changeset
  8545
  match(Set y (AndI (CmpLTMask p q) y));
fe66415573bf 6443505: Ideal() function for CmpLTMask
drchase
parents: 16624
diff changeset
  8546
  effect(KILL cr);
fe66415573bf 6443505: Ideal() function for CmpLTMask
drchase
parents: 16624
diff changeset
  8547
fe66415573bf 6443505: Ideal() function for CmpLTMask
drchase
parents: 16624
diff changeset
  8548
  ins_cost(300);
fe66415573bf 6443505: Ideal() function for CmpLTMask
drchase
parents: 16624
diff changeset
  8549
fe66415573bf 6443505: Ideal() function for CmpLTMask
drchase
parents: 16624
diff changeset
  8550
  format %{ "CMPL     $p, $q\t# and_cmpLTMask\n\t"
fe66415573bf 6443505: Ideal() function for CmpLTMask
drchase
parents: 16624
diff changeset
  8551
            "JLT      done\n\t"
fe66415573bf 6443505: Ideal() function for CmpLTMask
drchase
parents: 16624
diff changeset
  8552
            "XORL     $y, $y\n"
fe66415573bf 6443505: Ideal() function for CmpLTMask
drchase
parents: 16624
diff changeset
  8553
            "done:  " %}
fe66415573bf 6443505: Ideal() function for CmpLTMask
drchase
parents: 16624
diff changeset
  8554
  ins_encode %{
fe66415573bf 6443505: Ideal() function for CmpLTMask
drchase
parents: 16624
diff changeset
  8555
    Register Rp = $p$$Register;
fe66415573bf 6443505: Ideal() function for CmpLTMask
drchase
parents: 16624
diff changeset
  8556
    Register Rq = $q$$Register;
fe66415573bf 6443505: Ideal() function for CmpLTMask
drchase
parents: 16624
diff changeset
  8557
    Register Ry = $y$$Register;
fe66415573bf 6443505: Ideal() function for CmpLTMask
drchase
parents: 16624
diff changeset
  8558
    Label done;
fe66415573bf 6443505: Ideal() function for CmpLTMask
drchase
parents: 16624
diff changeset
  8559
    __ cmpl(Rp, Rq);
fe66415573bf 6443505: Ideal() function for CmpLTMask
drchase
parents: 16624
diff changeset
  8560
    __ jccb(Assembler::less, done);
fe66415573bf 6443505: Ideal() function for CmpLTMask
drchase
parents: 16624
diff changeset
  8561
    __ xorl(Ry, Ry);
fe66415573bf 6443505: Ideal() function for CmpLTMask
drchase
parents: 16624
diff changeset
  8562
    __ bind(done);
fe66415573bf 6443505: Ideal() function for CmpLTMask
drchase
parents: 16624
diff changeset
  8563
  %}
fe66415573bf 6443505: Ideal() function for CmpLTMask
drchase
parents: 16624
diff changeset
  8564
fe66415573bf 6443505: Ideal() function for CmpLTMask
drchase
parents: 16624
diff changeset
  8565
  ins_pipe(pipe_cmplt);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8566
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8567
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8568
/* If I enable this, I encourage spilling in the inner loop of compress.
17008
fe66415573bf 6443505: Ideal() function for CmpLTMask
drchase
parents: 16624
diff changeset
  8569
instruct cadd_cmpLTMask_mem(ncxRegI p, ncxRegI q, memory y, eCXRegI tmp, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8570
  match(Set p (AddI (AndI (CmpLTMask p q) (LoadI y)) (SubI p q)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8571
*/
22911
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8572
//----------Overflow Math Instructions-----------------------------------------
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8573
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8574
instruct overflowAddI_eReg(eFlagsReg cr, eAXRegI op1, rRegI op2)
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8575
%{
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8576
  match(Set cr (OverflowAddI op1 op2));
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8577
  effect(DEF cr, USE_KILL op1, USE op2);
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8578
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8579
  format %{ "ADD    $op1, $op2\t# overflow check int" %}
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8580
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8581
  ins_encode %{
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8582
    __ addl($op1$$Register, $op2$$Register);
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8583
  %}
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8584
  ins_pipe(ialu_reg_reg);
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8585
%}
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8586
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8587
instruct overflowAddI_rReg_imm(eFlagsReg cr, eAXRegI op1, immI op2)
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8588
%{
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8589
  match(Set cr (OverflowAddI op1 op2));
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8590
  effect(DEF cr, USE_KILL op1, USE op2);
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8591
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8592
  format %{ "ADD    $op1, $op2\t# overflow check int" %}
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8593
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8594
  ins_encode %{
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8595
    __ addl($op1$$Register, $op2$$constant);
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8596
  %}
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8597
  ins_pipe(ialu_reg_reg);
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8598
%}
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8599
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8600
instruct overflowSubI_rReg(eFlagsReg cr, rRegI op1, rRegI op2)
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8601
%{
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8602
  match(Set cr (OverflowSubI op1 op2));
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8603
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8604
  format %{ "CMP    $op1, $op2\t# overflow check int" %}
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8605
  ins_encode %{
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8606
    __ cmpl($op1$$Register, $op2$$Register);
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8607
  %}
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8608
  ins_pipe(ialu_reg_reg);
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8609
%}
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8610
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8611
instruct overflowSubI_rReg_imm(eFlagsReg cr, rRegI op1, immI op2)
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8612
%{
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8613
  match(Set cr (OverflowSubI op1 op2));
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8614
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8615
  format %{ "CMP    $op1, $op2\t# overflow check int" %}
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8616
  ins_encode %{
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8617
    __ cmpl($op1$$Register, $op2$$constant);
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8618
  %}
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8619
  ins_pipe(ialu_reg_reg);
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8620
%}
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8621
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8622
instruct overflowNegI_rReg(eFlagsReg cr, immI0 zero, eAXRegI op2)
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8623
%{
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8624
  match(Set cr (OverflowSubI zero op2));
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8625
  effect(DEF cr, USE_KILL op2);
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8626
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8627
  format %{ "NEG    $op2\t# overflow check int" %}
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8628
  ins_encode %{
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8629
    __ negl($op2$$Register);
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8630
  %}
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8631
  ins_pipe(ialu_reg_reg);
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8632
%}
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8633
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8634
instruct overflowMulI_rReg(eFlagsReg cr, eAXRegI op1, rRegI op2)
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8635
%{
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8636
  match(Set cr (OverflowMulI op1 op2));
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8637
  effect(DEF cr, USE_KILL op1, USE op2);
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8638
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8639
  format %{ "IMUL    $op1, $op2\t# overflow check int" %}
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8640
  ins_encode %{
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8641
    __ imull($op1$$Register, $op2$$Register);
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8642
  %}
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8643
  ins_pipe(ialu_reg_reg_alu0);
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8644
%}
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8645
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8646
instruct overflowMulI_rReg_imm(eFlagsReg cr, rRegI op1, immI op2, rRegI tmp)
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8647
%{
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8648
  match(Set cr (OverflowMulI op1 op2));
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8649
  effect(DEF cr, TEMP tmp, USE op1, USE op2);
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8650
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8651
  format %{ "IMUL    $tmp, $op1, $op2\t# overflow check int" %}
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8652
  ins_encode %{
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8653
    __ imull($tmp$$Register, $op1$$Register, $op2$$constant);
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8654
  %}
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8655
  ins_pipe(ialu_reg_reg_alu0);
ff49c48c887d 8027754: Enable loop optimizations for loops with MathExact inside
rbackman
parents: 22910
diff changeset
  8656
%}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8657
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8658
//----------Long Instructions------------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8659
// Add Long Register with Register
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8660
instruct addL_eReg(eRegL dst, eRegL src, eFlagsReg cr) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8661
  match(Set dst (AddL dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8662
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8663
  ins_cost(200);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8664
  format %{ "ADD    $dst.lo,$src.lo\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8665
            "ADC    $dst.hi,$src.hi" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8666
  opcode(0x03, 0x13);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8667
  ins_encode( RegReg_Lo(dst, src), RegReg_Hi(dst,src) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8668
  ins_pipe( ialu_reg_reg_long );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8669
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8670
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8671
// Add Long Register with Immediate
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8672
instruct addL_eReg_imm(eRegL dst, immL src, eFlagsReg cr) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8673
  match(Set dst (AddL dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8674
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8675
  format %{ "ADD    $dst.lo,$src.lo\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8676
            "ADC    $dst.hi,$src.hi" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8677
  opcode(0x81,0x00,0x02);  /* Opcode 81 /0, 81 /2 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8678
  ins_encode( Long_OpcSErm_Lo( dst, src ), Long_OpcSErm_Hi( dst, src ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8679
  ins_pipe( ialu_reg_long );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8680
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8681
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8682
// Add Long Register with Memory
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8683
instruct addL_eReg_mem(eRegL dst, load_long_memory mem, eFlagsReg cr) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8684
  match(Set dst (AddL dst (LoadL mem)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8685
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8686
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8687
  format %{ "ADD    $dst.lo,$mem\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8688
            "ADC    $dst.hi,$mem+4" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8689
  opcode(0x03, 0x13);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8690
  ins_encode( OpcP, RegMem( dst, mem), OpcS, RegMem_Hi(dst,mem) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8691
  ins_pipe( ialu_reg_long_mem );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8692
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8693
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8694
// Subtract Long Register with Register.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8695
instruct subL_eReg(eRegL dst, eRegL src, eFlagsReg cr) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8696
  match(Set dst (SubL dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8697
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8698
  ins_cost(200);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8699
  format %{ "SUB    $dst.lo,$src.lo\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8700
            "SBB    $dst.hi,$src.hi" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8701
  opcode(0x2B, 0x1B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8702
  ins_encode( RegReg_Lo(dst, src), RegReg_Hi(dst,src) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8703
  ins_pipe( ialu_reg_reg_long );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8704
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8705
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8706
// Subtract Long Register with Immediate
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8707
instruct subL_eReg_imm(eRegL dst, immL src, eFlagsReg cr) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8708
  match(Set dst (SubL dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8709
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8710
  format %{ "SUB    $dst.lo,$src.lo\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8711
            "SBB    $dst.hi,$src.hi" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8712
  opcode(0x81,0x05,0x03);  /* Opcode 81 /5, 81 /3 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8713
  ins_encode( Long_OpcSErm_Lo( dst, src ), Long_OpcSErm_Hi( dst, src ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8714
  ins_pipe( ialu_reg_long );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8715
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8716
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8717
// Subtract Long Register with Memory
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8718
instruct subL_eReg_mem(eRegL dst, load_long_memory mem, eFlagsReg cr) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8719
  match(Set dst (SubL dst (LoadL mem)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8720
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8721
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8722
  format %{ "SUB    $dst.lo,$mem\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8723
            "SBB    $dst.hi,$mem+4" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8724
  opcode(0x2B, 0x1B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8725
  ins_encode( OpcP, RegMem( dst, mem), OpcS, RegMem_Hi(dst,mem) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8726
  ins_pipe( ialu_reg_long_mem );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8727
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8728
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8729
instruct negL_eReg(eRegL dst, immL0 zero, eFlagsReg cr) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8730
  match(Set dst (SubL zero dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8731
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8732
  ins_cost(300);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8733
  format %{ "NEG    $dst.hi\n\tNEG    $dst.lo\n\tSBB    $dst.hi,0" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8734
  ins_encode( neg_long(dst) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8735
  ins_pipe( ialu_reg_reg_long );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8736
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8737
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8738
// And Long Register with Register
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8739
instruct andL_eReg(eRegL dst, eRegL src, eFlagsReg cr) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8740
  match(Set dst (AndL dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8741
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8742
  format %{ "AND    $dst.lo,$src.lo\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8743
            "AND    $dst.hi,$src.hi" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8744
  opcode(0x23,0x23);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8745
  ins_encode( RegReg_Lo( dst, src), RegReg_Hi( dst, src) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8746
  ins_pipe( ialu_reg_reg_long );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8747
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8748
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8749
// And Long Register with Immediate
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8750
instruct andL_eReg_imm(eRegL dst, immL src, eFlagsReg cr) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8751
  match(Set dst (AndL dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8752
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8753
  format %{ "AND    $dst.lo,$src.lo\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8754
            "AND    $dst.hi,$src.hi" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8755
  opcode(0x81,0x04,0x04);  /* Opcode 81 /4, 81 /4 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8756
  ins_encode( Long_OpcSErm_Lo( dst, src ), Long_OpcSErm_Hi( dst, src ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8757
  ins_pipe( ialu_reg_long );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8758
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8759
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8760
// And Long Register with Memory
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8761
instruct andL_eReg_mem(eRegL dst, load_long_memory mem, eFlagsReg cr) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8762
  match(Set dst (AndL dst (LoadL mem)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8763
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8764
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8765
  format %{ "AND    $dst.lo,$mem\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8766
            "AND    $dst.hi,$mem+4" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8767
  opcode(0x23, 0x23);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8768
  ins_encode( OpcP, RegMem( dst, mem), OpcS, RegMem_Hi(dst,mem) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8769
  ins_pipe( ialu_reg_long_mem );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8770
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8771
23220
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8772
// BMI1 instructions
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8773
instruct andnL_eReg_eReg_eReg(eRegL dst, eRegL src1, eRegL src2, immL_M1 minus_1, eFlagsReg cr) %{
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8774
  match(Set dst (AndL (XorL src1 minus_1) src2));
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8775
  predicate(UseBMI1Instructions);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8776
  effect(KILL cr, TEMP dst);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8777
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8778
  format %{ "ANDNL  $dst.lo, $src1.lo, $src2.lo\n\t"
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8779
            "ANDNL  $dst.hi, $src1.hi, $src2.hi"
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8780
         %}
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8781
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8782
  ins_encode %{
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8783
    Register Rdst = $dst$$Register;
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8784
    Register Rsrc1 = $src1$$Register;
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8785
    Register Rsrc2 = $src2$$Register;
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8786
    __ andnl(Rdst, Rsrc1, Rsrc2);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8787
    __ andnl(HIGH_FROM_LOW(Rdst), HIGH_FROM_LOW(Rsrc1), HIGH_FROM_LOW(Rsrc2));
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8788
  %}
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8789
  ins_pipe(ialu_reg_reg_long);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8790
%}
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8791
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8792
instruct andnL_eReg_eReg_mem(eRegL dst, eRegL src1, memory src2, immL_M1 minus_1, eFlagsReg cr) %{
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8793
  match(Set dst (AndL (XorL src1 minus_1) (LoadL src2) ));
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8794
  predicate(UseBMI1Instructions);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8795
  effect(KILL cr, TEMP dst);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8796
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8797
  ins_cost(125);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8798
  format %{ "ANDNL  $dst.lo, $src1.lo, $src2\n\t"
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8799
            "ANDNL  $dst.hi, $src1.hi, $src2+4"
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8800
         %}
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8801
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8802
  ins_encode %{
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8803
    Register Rdst = $dst$$Register;
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8804
    Register Rsrc1 = $src1$$Register;
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8805
    Address src2_hi = Address::make_raw($src2$$base, $src2$$index, $src2$$scale, $src2$$disp + 4, relocInfo::none);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8806
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8807
    __ andnl(Rdst, Rsrc1, $src2$$Address);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8808
    __ andnl(HIGH_FROM_LOW(Rdst), HIGH_FROM_LOW(Rsrc1), src2_hi);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8809
  %}
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8810
  ins_pipe(ialu_reg_mem);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8811
%}
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8812
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8813
instruct blsiL_eReg_eReg(eRegL dst, eRegL src, immL0 imm_zero, eFlagsReg cr) %{
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8814
  match(Set dst (AndL (SubL imm_zero src) src));
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8815
  predicate(UseBMI1Instructions);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8816
  effect(KILL cr, TEMP dst);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8817
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8818
  format %{ "MOVL   $dst.hi, 0\n\t"
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8819
            "BLSIL  $dst.lo, $src.lo\n\t"
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8820
            "JNZ    done\n\t"
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8821
            "BLSIL  $dst.hi, $src.hi\n"
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8822
            "done:"
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8823
         %}
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8824
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8825
  ins_encode %{
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8826
    Label done;
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8827
    Register Rdst = $dst$$Register;
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8828
    Register Rsrc = $src$$Register;
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8829
    __ movl(HIGH_FROM_LOW(Rdst), 0);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8830
    __ blsil(Rdst, Rsrc);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8831
    __ jccb(Assembler::notZero, done);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8832
    __ blsil(HIGH_FROM_LOW(Rdst), HIGH_FROM_LOW(Rsrc));
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8833
    __ bind(done);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8834
  %}
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8835
  ins_pipe(ialu_reg);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8836
%}
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8837
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8838
instruct blsiL_eReg_mem(eRegL dst, memory src, immL0 imm_zero, eFlagsReg cr) %{
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8839
  match(Set dst (AndL (SubL imm_zero (LoadL src) ) (LoadL src) ));
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8840
  predicate(UseBMI1Instructions);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8841
  effect(KILL cr, TEMP dst);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8842
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8843
  ins_cost(125);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8844
  format %{ "MOVL   $dst.hi, 0\n\t"
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8845
            "BLSIL  $dst.lo, $src\n\t"
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8846
            "JNZ    done\n\t"
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8847
            "BLSIL  $dst.hi, $src+4\n"
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8848
            "done:"
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8849
         %}
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8850
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8851
  ins_encode %{
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8852
    Label done;
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8853
    Register Rdst = $dst$$Register;
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8854
    Address src_hi = Address::make_raw($src$$base, $src$$index, $src$$scale, $src$$disp + 4, relocInfo::none);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8855
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8856
    __ movl(HIGH_FROM_LOW(Rdst), 0);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8857
    __ blsil(Rdst, $src$$Address);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8858
    __ jccb(Assembler::notZero, done);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8859
    __ blsil(HIGH_FROM_LOW(Rdst), src_hi);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8860
    __ bind(done);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8861
  %}
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8862
  ins_pipe(ialu_reg_mem);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8863
%}
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8864
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8865
instruct blsmskL_eReg_eReg(eRegL dst, eRegL src, immL_M1 minus_1, eFlagsReg cr)
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8866
%{
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8867
  match(Set dst (XorL (AddL src minus_1) src));
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8868
  predicate(UseBMI1Instructions);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8869
  effect(KILL cr, TEMP dst);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8870
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8871
  format %{ "MOVL    $dst.hi, 0\n\t"
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8872
            "BLSMSKL $dst.lo, $src.lo\n\t"
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8873
            "JNC     done\n\t"
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8874
            "BLSMSKL $dst.hi, $src.hi\n"
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8875
            "done:"
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8876
         %}
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8877
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8878
  ins_encode %{
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8879
    Label done;
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8880
    Register Rdst = $dst$$Register;
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8881
    Register Rsrc = $src$$Register;
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8882
    __ movl(HIGH_FROM_LOW(Rdst), 0);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8883
    __ blsmskl(Rdst, Rsrc);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8884
    __ jccb(Assembler::carryClear, done);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8885
    __ blsmskl(HIGH_FROM_LOW(Rdst), HIGH_FROM_LOW(Rsrc));
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8886
    __ bind(done);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8887
  %}
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8888
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8889
  ins_pipe(ialu_reg);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8890
%}
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8891
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8892
instruct blsmskL_eReg_mem(eRegL dst, memory src, immL_M1 minus_1, eFlagsReg cr)
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8893
%{
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8894
  match(Set dst (XorL (AddL (LoadL src) minus_1) (LoadL src) ));
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8895
  predicate(UseBMI1Instructions);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8896
  effect(KILL cr, TEMP dst);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8897
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8898
  ins_cost(125);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8899
  format %{ "MOVL    $dst.hi, 0\n\t"
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8900
            "BLSMSKL $dst.lo, $src\n\t"
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8901
            "JNC     done\n\t"
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8902
            "BLSMSKL $dst.hi, $src+4\n"
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8903
            "done:"
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8904
         %}
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8905
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8906
  ins_encode %{
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8907
    Label done;
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8908
    Register Rdst = $dst$$Register;
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8909
    Address src_hi = Address::make_raw($src$$base, $src$$index, $src$$scale, $src$$disp + 4, relocInfo::none);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8910
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8911
    __ movl(HIGH_FROM_LOW(Rdst), 0);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8912
    __ blsmskl(Rdst, $src$$Address);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8913
    __ jccb(Assembler::carryClear, done);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8914
    __ blsmskl(HIGH_FROM_LOW(Rdst), src_hi);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8915
    __ bind(done);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8916
  %}
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8917
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8918
  ins_pipe(ialu_reg_mem);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8919
%}
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8920
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8921
instruct blsrL_eReg_eReg(eRegL dst, eRegL src, immL_M1 minus_1, eFlagsReg cr)
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8922
%{
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8923
  match(Set dst (AndL (AddL src minus_1) src) );
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8924
  predicate(UseBMI1Instructions);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8925
  effect(KILL cr, TEMP dst);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8926
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8927
  format %{ "MOVL   $dst.hi, $src.hi\n\t"
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8928
            "BLSRL  $dst.lo, $src.lo\n\t"
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8929
            "JNC    done\n\t"
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8930
            "BLSRL  $dst.hi, $src.hi\n"
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8931
            "done:"
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8932
  %}
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8933
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8934
  ins_encode %{
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8935
    Label done;
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8936
    Register Rdst = $dst$$Register;
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8937
    Register Rsrc = $src$$Register;
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8938
    __ movl(HIGH_FROM_LOW(Rdst), HIGH_FROM_LOW(Rsrc));
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8939
    __ blsrl(Rdst, Rsrc);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8940
    __ jccb(Assembler::carryClear, done);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8941
    __ blsrl(HIGH_FROM_LOW(Rdst), HIGH_FROM_LOW(Rsrc));
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8942
    __ bind(done);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8943
  %}
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8944
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8945
  ins_pipe(ialu_reg);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8946
%}
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8947
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8948
instruct blsrL_eReg_mem(eRegL dst, memory src, immL_M1 minus_1, eFlagsReg cr)
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8949
%{
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8950
  match(Set dst (AndL (AddL (LoadL src) minus_1) (LoadL src) ));
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8951
  predicate(UseBMI1Instructions);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8952
  effect(KILL cr, TEMP dst);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8953
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8954
  ins_cost(125);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8955
  format %{ "MOVL   $dst.hi, $src+4\n\t"
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8956
            "BLSRL  $dst.lo, $src\n\t"
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8957
            "JNC    done\n\t"
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8958
            "BLSRL  $dst.hi, $src+4\n"
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8959
            "done:"
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8960
  %}
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8961
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8962
  ins_encode %{
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8963
    Label done;
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8964
    Register Rdst = $dst$$Register;
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8965
    Address src_hi = Address::make_raw($src$$base, $src$$index, $src$$scale, $src$$disp + 4, relocInfo::none);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8966
    __ movl(HIGH_FROM_LOW(Rdst), src_hi);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8967
    __ blsrl(Rdst, $src$$Address);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8968
    __ jccb(Assembler::carryClear, done);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8969
    __ blsrl(HIGH_FROM_LOW(Rdst), src_hi);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8970
    __ bind(done);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8971
  %}
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8972
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8973
  ins_pipe(ialu_reg_mem);
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8974
%}
fc827339dc37 8031321: Support Intel bit manipulation instructions
iveresov
parents: 22911
diff changeset
  8975
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8976
// Or Long Register with Register
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8977
instruct orl_eReg(eRegL dst, eRegL src, eFlagsReg cr) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8978
  match(Set dst (OrL dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8979
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8980
  format %{ "OR     $dst.lo,$src.lo\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8981
            "OR     $dst.hi,$src.hi" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8982
  opcode(0x0B,0x0B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8983
  ins_encode( RegReg_Lo( dst, src), RegReg_Hi( dst, src) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8984
  ins_pipe( ialu_reg_reg_long );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8985
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8986
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8987
// Or Long Register with Immediate
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8988
instruct orl_eReg_imm(eRegL dst, immL src, eFlagsReg cr) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8989
  match(Set dst (OrL dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8990
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8991
  format %{ "OR     $dst.lo,$src.lo\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8992
            "OR     $dst.hi,$src.hi" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8993
  opcode(0x81,0x01,0x01);  /* Opcode 81 /1, 81 /1 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8994
  ins_encode( Long_OpcSErm_Lo( dst, src ), Long_OpcSErm_Hi( dst, src ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8995
  ins_pipe( ialu_reg_long );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8996
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8997
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8998
// Or Long Register with Memory
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8999
instruct orl_eReg_mem(eRegL dst, load_long_memory mem, eFlagsReg cr) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9000
  match(Set dst (OrL dst (LoadL mem)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9001
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9002
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9003
  format %{ "OR     $dst.lo,$mem\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9004
            "OR     $dst.hi,$mem+4" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9005
  opcode(0x0B,0x0B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9006
  ins_encode( OpcP, RegMem( dst, mem), OpcS, RegMem_Hi(dst,mem) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9007
  ins_pipe( ialu_reg_long_mem );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9008
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9009
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9010
// Xor Long Register with Register
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9011
instruct xorl_eReg(eRegL dst, eRegL src, eFlagsReg cr) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9012
  match(Set dst (XorL dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9013
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9014
  format %{ "XOR    $dst.lo,$src.lo\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9015
            "XOR    $dst.hi,$src.hi" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9016
  opcode(0x33,0x33);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9017
  ins_encode( RegReg_Lo( dst, src), RegReg_Hi( dst, src) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9018
  ins_pipe( ialu_reg_reg_long );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9019
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9020
1435
72a8da703ff0 6752257: Use NOT instead of XOR -1 on x86
rasbold
parents: 1066
diff changeset
  9021
// Xor Long Register with Immediate -1
72a8da703ff0 6752257: Use NOT instead of XOR -1 on x86
rasbold
parents: 1066
diff changeset
  9022
instruct xorl_eReg_im1(eRegL dst, immL_M1 imm) %{
30624
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
  9023
  match(Set dst (XorL dst imm));
1435
72a8da703ff0 6752257: Use NOT instead of XOR -1 on x86
rasbold
parents: 1066
diff changeset
  9024
  format %{ "NOT    $dst.lo\n\t"
72a8da703ff0 6752257: Use NOT instead of XOR -1 on x86
rasbold
parents: 1066
diff changeset
  9025
            "NOT    $dst.hi" %}
72a8da703ff0 6752257: Use NOT instead of XOR -1 on x86
rasbold
parents: 1066
diff changeset
  9026
  ins_encode %{
72a8da703ff0 6752257: Use NOT instead of XOR -1 on x86
rasbold
parents: 1066
diff changeset
  9027
     __ notl($dst$$Register);
72a8da703ff0 6752257: Use NOT instead of XOR -1 on x86
rasbold
parents: 1066
diff changeset
  9028
     __ notl(HIGH_FROM_LOW($dst$$Register));
72a8da703ff0 6752257: Use NOT instead of XOR -1 on x86
rasbold
parents: 1066
diff changeset
  9029
  %}
72a8da703ff0 6752257: Use NOT instead of XOR -1 on x86
rasbold
parents: 1066
diff changeset
  9030
  ins_pipe( ialu_reg_long );
72a8da703ff0 6752257: Use NOT instead of XOR -1 on x86
rasbold
parents: 1066
diff changeset
  9031
%}
72a8da703ff0 6752257: Use NOT instead of XOR -1 on x86
rasbold
parents: 1066
diff changeset
  9032
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9033
// Xor Long Register with Immediate
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9034
instruct xorl_eReg_imm(eRegL dst, immL src, eFlagsReg cr) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9035
  match(Set dst (XorL dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9036
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9037
  format %{ "XOR    $dst.lo,$src.lo\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9038
            "XOR    $dst.hi,$src.hi" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9039
  opcode(0x81,0x06,0x06);  /* Opcode 81 /6, 81 /6 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9040
  ins_encode( Long_OpcSErm_Lo( dst, src ), Long_OpcSErm_Hi( dst, src ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9041
  ins_pipe( ialu_reg_long );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9042
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9043
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9044
// Xor Long Register with Memory
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9045
instruct xorl_eReg_mem(eRegL dst, load_long_memory mem, eFlagsReg cr) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9046
  match(Set dst (XorL dst (LoadL mem)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9047
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9048
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9049
  format %{ "XOR    $dst.lo,$mem\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9050
            "XOR    $dst.hi,$mem+4" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9051
  opcode(0x33,0x33);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9052
  ins_encode( OpcP, RegMem( dst, mem), OpcS, RegMem_Hi(dst,mem) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9053
  ins_pipe( ialu_reg_long_mem );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9054
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9055
765
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  9056
// Shift Left Long by 1
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  9057
instruct shlL_eReg_1(eRegL dst, immI_1 cnt, eFlagsReg cr) %{
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  9058
  predicate(UseNewLongLShift);
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  9059
  match(Set dst (LShiftL dst cnt));
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  9060
  effect(KILL cr);
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  9061
  ins_cost(100);
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  9062
  format %{ "ADD    $dst.lo,$dst.lo\n\t"
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  9063
            "ADC    $dst.hi,$dst.hi" %}
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  9064
  ins_encode %{
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  9065
    __ addl($dst$$Register,$dst$$Register);
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  9066
    __ adcl(HIGH_FROM_LOW($dst$$Register),HIGH_FROM_LOW($dst$$Register));
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  9067
  %}
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  9068
  ins_pipe( ialu_reg_long );
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  9069
%}
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  9070
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  9071
// Shift Left Long by 2
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  9072
instruct shlL_eReg_2(eRegL dst, immI_2 cnt, eFlagsReg cr) %{
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  9073
  predicate(UseNewLongLShift);
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  9074
  match(Set dst (LShiftL dst cnt));
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  9075
  effect(KILL cr);
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  9076
  ins_cost(100);
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  9077
  format %{ "ADD    $dst.lo,$dst.lo\n\t"
30624
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
  9078
            "ADC    $dst.hi,$dst.hi\n\t"
765
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  9079
            "ADD    $dst.lo,$dst.lo\n\t"
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  9080
            "ADC    $dst.hi,$dst.hi" %}
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  9081
  ins_encode %{
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  9082
    __ addl($dst$$Register,$dst$$Register);
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  9083
    __ adcl(HIGH_FROM_LOW($dst$$Register),HIGH_FROM_LOW($dst$$Register));
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  9084
    __ addl($dst$$Register,$dst$$Register);
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  9085
    __ adcl(HIGH_FROM_LOW($dst$$Register),HIGH_FROM_LOW($dst$$Register));
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  9086
  %}
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  9087
  ins_pipe( ialu_reg_long );
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  9088
%}
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  9089
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  9090
// Shift Left Long by 3
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  9091
instruct shlL_eReg_3(eRegL dst, immI_3 cnt, eFlagsReg cr) %{
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  9092
  predicate(UseNewLongLShift);
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  9093
  match(Set dst (LShiftL dst cnt));
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  9094
  effect(KILL cr);
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  9095
  ins_cost(100);
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  9096
  format %{ "ADD    $dst.lo,$dst.lo\n\t"
30624
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
  9097
            "ADC    $dst.hi,$dst.hi\n\t"
765
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  9098
            "ADD    $dst.lo,$dst.lo\n\t"
30624
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
  9099
            "ADC    $dst.hi,$dst.hi\n\t"
765
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  9100
            "ADD    $dst.lo,$dst.lo\n\t"
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  9101
            "ADC    $dst.hi,$dst.hi" %}
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  9102
  ins_encode %{
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  9103
    __ addl($dst$$Register,$dst$$Register);
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  9104
    __ adcl(HIGH_FROM_LOW($dst$$Register),HIGH_FROM_LOW($dst$$Register));
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  9105
    __ addl($dst$$Register,$dst$$Register);
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  9106
    __ adcl(HIGH_FROM_LOW($dst$$Register),HIGH_FROM_LOW($dst$$Register));
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  9107
    __ addl($dst$$Register,$dst$$Register);
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  9108
    __ adcl(HIGH_FROM_LOW($dst$$Register),HIGH_FROM_LOW($dst$$Register));
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  9109
  %}
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  9110
  ins_pipe( ialu_reg_long );
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  9111
%}
e0692d3d8863 6708714: Optimize long LShift on 32-bits x86
kvn
parents: 595
diff changeset
  9112
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9113
// Shift Left Long by 1-31
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9114
instruct shlL_eReg_1_31(eRegL dst, immI_1_31 cnt, eFlagsReg cr) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9115
  match(Set dst (LShiftL dst cnt));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9116
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9117
  ins_cost(200);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9118
  format %{ "SHLD   $dst.hi,$dst.lo,$cnt\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9119
            "SHL    $dst.lo,$cnt" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9120
  opcode(0xC1, 0x4, 0xA4);  /* 0F/A4, then C1 /4 ib */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9121
  ins_encode( move_long_small_shift(dst,cnt) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9122
  ins_pipe( ialu_reg_long );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9123
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9124
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9125
// Shift Left Long by 32-63
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9126
instruct shlL_eReg_32_63(eRegL dst, immI_32_63 cnt, eFlagsReg cr) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9127
  match(Set dst (LShiftL dst cnt));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9128
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9129
  ins_cost(300);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9130
  format %{ "MOV    $dst.hi,$dst.lo\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9131
          "\tSHL    $dst.hi,$cnt-32\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9132
          "\tXOR    $dst.lo,$dst.lo" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9133
  opcode(0xC1, 0x4);  /* C1 /4 ib */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9134
  ins_encode( move_long_big_shift_clr(dst,cnt) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9135
  ins_pipe( ialu_reg_long );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9136
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9137
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9138
// Shift Left Long by variable
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9139
instruct salL_eReg_CL(eRegL dst, eCXRegI shift, eFlagsReg cr) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9140
  match(Set dst (LShiftL dst shift));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9141
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9142
  ins_cost(500+200);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9143
  size(17);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9144
  format %{ "TEST   $shift,32\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9145
            "JEQ,s  small\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9146
            "MOV    $dst.hi,$dst.lo\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9147
            "XOR    $dst.lo,$dst.lo\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9148
    "small:\tSHLD   $dst.hi,$dst.lo,$shift\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9149
            "SHL    $dst.lo,$shift" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9150
  ins_encode( shift_left_long( dst, shift ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9151
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9152
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9153
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9154
// Shift Right Long by 1-31
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9155
instruct shrL_eReg_1_31(eRegL dst, immI_1_31 cnt, eFlagsReg cr) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9156
  match(Set dst (URShiftL dst cnt));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9157
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9158
  ins_cost(200);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9159
  format %{ "SHRD   $dst.lo,$dst.hi,$cnt\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9160
            "SHR    $dst.hi,$cnt" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9161
  opcode(0xC1, 0x5, 0xAC);  /* 0F/AC, then C1 /5 ib */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9162
  ins_encode( move_long_small_shift(dst,cnt) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9163
  ins_pipe( ialu_reg_long );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9164
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9165
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9166
// Shift Right Long by 32-63
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9167
instruct shrL_eReg_32_63(eRegL dst, immI_32_63 cnt, eFlagsReg cr) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9168
  match(Set dst (URShiftL dst cnt));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9169
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9170
  ins_cost(300);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9171
  format %{ "MOV    $dst.lo,$dst.hi\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9172
          "\tSHR    $dst.lo,$cnt-32\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9173
          "\tXOR    $dst.hi,$dst.hi" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9174
  opcode(0xC1, 0x5);  /* C1 /5 ib */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9175
  ins_encode( move_long_big_shift_clr(dst,cnt) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9176
  ins_pipe( ialu_reg_long );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9177
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9178
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9179
// Shift Right Long by variable
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9180
instruct shrL_eReg_CL(eRegL dst, eCXRegI shift, eFlagsReg cr) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9181
  match(Set dst (URShiftL dst shift));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9182
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9183
  ins_cost(600);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9184
  size(17);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9185
  format %{ "TEST   $shift,32\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9186
            "JEQ,s  small\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9187
            "MOV    $dst.lo,$dst.hi\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9188
            "XOR    $dst.hi,$dst.hi\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9189
    "small:\tSHRD   $dst.lo,$dst.hi,$shift\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9190
            "SHR    $dst.hi,$shift" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9191
  ins_encode( shift_right_long( dst, shift ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9192
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9193
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9194
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9195
// Shift Right Long by 1-31
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9196
instruct sarL_eReg_1_31(eRegL dst, immI_1_31 cnt, eFlagsReg cr) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9197
  match(Set dst (RShiftL dst cnt));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9198
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9199
  ins_cost(200);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9200
  format %{ "SHRD   $dst.lo,$dst.hi,$cnt\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9201
            "SAR    $dst.hi,$cnt" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9202
  opcode(0xC1, 0x7, 0xAC);  /* 0F/AC, then C1 /7 ib */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9203
  ins_encode( move_long_small_shift(dst,cnt) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9204
  ins_pipe( ialu_reg_long );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9205
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9206
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9207
// Shift Right Long by 32-63
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9208
instruct sarL_eReg_32_63( eRegL dst, immI_32_63 cnt, eFlagsReg cr) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9209
  match(Set dst (RShiftL dst cnt));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9210
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9211
  ins_cost(300);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9212
  format %{ "MOV    $dst.lo,$dst.hi\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9213
          "\tSAR    $dst.lo,$cnt-32\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9214
          "\tSAR    $dst.hi,31" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9215
  opcode(0xC1, 0x7);  /* C1 /7 ib */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9216
  ins_encode( move_long_big_shift_sign(dst,cnt) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9217
  ins_pipe( ialu_reg_long );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9218
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9219
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9220
// Shift Right arithmetic Long by variable
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9221
instruct sarL_eReg_CL(eRegL dst, eCXRegI shift, eFlagsReg cr) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9222
  match(Set dst (RShiftL dst shift));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9223
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9224
  ins_cost(600);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9225
  size(18);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9226
  format %{ "TEST   $shift,32\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9227
            "JEQ,s  small\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9228
            "MOV    $dst.lo,$dst.hi\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9229
            "SAR    $dst.hi,31\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9230
    "small:\tSHRD   $dst.lo,$dst.hi,$shift\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9231
            "SAR    $dst.hi,$shift" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9232
  ins_encode( shift_right_arith_long( dst, shift ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9233
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9234
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9235
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9236
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9237
//----------Double Instructions------------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9238
// Double Math
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9239
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9240
// Compare & branch
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9241
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9242
// P6 version of float compare, sets condition codes in EFLAGS
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9243
instruct cmpDPR_cc_P6(eFlagsRegU cr, regDPR src1, regDPR src2, eAXRegI rax) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9244
  predicate(VM_Version::supports_cmov() && UseSSE <=1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9245
  match(Set cr (CmpD src1 src2));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9246
  effect(KILL rax);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9247
  ins_cost(150);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9248
  format %{ "FLD    $src1\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9249
            "FUCOMIP ST,$src2  // P6 instruction\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9250
            "JNP    exit\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9251
            "MOV    ah,1       // saw a NaN, set CF\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9252
            "SAHF\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9253
     "exit:\tNOP               // avoid branch to branch" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9254
  opcode(0xDF, 0x05); /* DF E8+i or DF /5 */
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9255
  ins_encode( Push_Reg_DPR(src1),
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9256
              OpcP, RegOpc(src2),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9257
              cmpF_P6_fixup );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9258
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9259
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9260
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9261
instruct cmpDPR_cc_P6CF(eFlagsRegUCF cr, regDPR src1, regDPR src2) %{
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  9262
  predicate(VM_Version::supports_cmov() && UseSSE <=1);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  9263
  match(Set cr (CmpD src1 src2));
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  9264
  ins_cost(150);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  9265
  format %{ "FLD    $src1\n\t"
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  9266
            "FUCOMIP ST,$src2  // P6 instruction" %}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  9267
  opcode(0xDF, 0x05); /* DF E8+i or DF /5 */
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9268
  ins_encode( Push_Reg_DPR(src1),
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  9269
              OpcP, RegOpc(src2));
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  9270
  ins_pipe( pipe_slow );
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  9271
%}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  9272
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9273
// Compare & branch
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9274
instruct cmpDPR_cc(eFlagsRegU cr, regDPR src1, regDPR src2, eAXRegI rax) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9275
  predicate(UseSSE<=1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9276
  match(Set cr (CmpD src1 src2));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9277
  effect(KILL rax);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9278
  ins_cost(200);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9279
  format %{ "FLD    $src1\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9280
            "FCOMp  $src2\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9281
            "FNSTSW AX\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9282
            "TEST   AX,0x400\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9283
            "JZ,s   flags\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9284
            "MOV    AH,1\t# unordered treat as LT\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9285
    "flags:\tSAHF" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9286
  opcode(0xD8, 0x3); /* D8 D8+i or D8 /3 */
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9287
  ins_encode( Push_Reg_DPR(src1),
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9288
              OpcP, RegOpc(src2),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9289
              fpu_flags);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9290
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9291
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9292
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9293
// Compare vs zero into -1,0,1
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  9294
instruct cmpDPR_0(rRegI dst, regDPR src1, immDPR0 zero, eAXRegI rax, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9295
  predicate(UseSSE<=1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9296
  match(Set dst (CmpD3 src1 zero));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9297
  effect(KILL cr, KILL rax);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9298
  ins_cost(280);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9299
  format %{ "FTSTD  $dst,$src1" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9300
  opcode(0xE4, 0xD9);
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9301
  ins_encode( Push_Reg_DPR(src1),
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9302
              OpcS, OpcP, PopFPU,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9303
              CmpF_Result(dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9304
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9305
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9306
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9307
// Compare into -1,0,1
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
  9308
instruct cmpDPR_reg(rRegI dst, regDPR src1, regDPR src2, eAXRegI rax, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9309
  predicate(UseSSE<=1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9310
  match(Set dst (CmpD3 src1 src2));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9311
  effect(KILL cr, KILL rax);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9312
  ins_cost(300);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9313
  format %{ "FCMPD  $dst,$src1,$src2" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9314
  opcode(0xD8, 0x3); /* D8 D8+i or D8 /3 */
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9315
  ins_encode( Push_Reg_DPR(src1),
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9316
              OpcP, RegOpc(src2),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9317
              CmpF_Result(dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9318
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9319
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9320
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9321
// float compare and set condition codes in EFLAGS by XMM regs
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9322
instruct cmpD_cc(eFlagsRegU cr, regD src1, regD src2) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9323
  predicate(UseSSE>=2);
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  9324
  match(Set cr (CmpD src1 src2));
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  9325
  ins_cost(145);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  9326
  format %{ "UCOMISD $src1,$src2\n\t"
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  9327
            "JNP,s   exit\n\t"
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  9328
            "PUSHF\t# saw NaN, set CF\n\t"
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  9329
            "AND     [rsp], #0xffffff2b\n\t"
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  9330
            "POPF\n"
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  9331
    "exit:" %}
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  9332
  ins_encode %{
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  9333
    __ ucomisd($src1$$XMMRegister, $src2$$XMMRegister);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  9334
    emit_cmpfp_fixup(_masm);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  9335
  %}
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  9336
  ins_pipe( pipe_slow );
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  9337
%}
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  9338
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9339
instruct cmpD_ccCF(eFlagsRegUCF cr, regD src1, regD src2) %{
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  9340
  predicate(UseSSE>=2);
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  9341
  match(Set cr (CmpD src1 src2));
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  9342
  ins_cost(100);
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  9343
  format %{ "UCOMISD $src1,$src2" %}
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  9344
  ins_encode %{
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  9345
    __ ucomisd($src1$$XMMRegister, $src2$$XMMRegister);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  9346
  %}
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  9347
  ins_pipe( pipe_slow );
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  9348
%}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  9349
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9350
// float compare and set condition codes in EFLAGS by XMM regs
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9351
instruct cmpD_ccmem(eFlagsRegU cr, regD src1, memory src2) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9352
  predicate(UseSSE>=2);
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  9353
  match(Set cr (CmpD src1 (LoadD src2)));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9354
  ins_cost(145);
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  9355
  format %{ "UCOMISD $src1,$src2\n\t"
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  9356
            "JNP,s   exit\n\t"
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  9357
            "PUSHF\t# saw NaN, set CF\n\t"
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  9358
            "AND     [rsp], #0xffffff2b\n\t"
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  9359
            "POPF\n"
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  9360
    "exit:" %}
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  9361
  ins_encode %{
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  9362
    __ ucomisd($src1$$XMMRegister, $src2$$Address);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  9363
    emit_cmpfp_fixup(_masm);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  9364
  %}
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  9365
  ins_pipe( pipe_slow );
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  9366
%}
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  9367
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9368
instruct cmpD_ccmemCF(eFlagsRegUCF cr, regD src1, memory src2) %{
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  9369
  predicate(UseSSE>=2);
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  9370
  match(Set cr (CmpD src1 (LoadD src2)));
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  9371
  ins_cost(100);
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  9372
  format %{ "UCOMISD $src1,$src2" %}
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  9373
  ins_encode %{
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  9374
    __ ucomisd($src1$$XMMRegister, $src2$$Address);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  9375
  %}
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  9376
  ins_pipe( pipe_slow );
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  9377
%}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  9378
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9379
// Compare into -1,0,1 in XMM
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9380
instruct cmpD_reg(xRegI dst, regD src1, regD src2, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9381
  predicate(UseSSE>=2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9382
  match(Set dst (CmpD3 src1 src2));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9383
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9384
  ins_cost(255);
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  9385
  format %{ "UCOMISD $src1, $src2\n\t"
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  9386
            "MOV     $dst, #-1\n\t"
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  9387
            "JP,s    done\n\t"
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  9388
            "JB,s    done\n\t"
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  9389
            "SETNE   $dst\n\t"
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  9390
            "MOVZB   $dst, $dst\n"
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  9391
    "done:" %}
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  9392
  ins_encode %{
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  9393
    __ ucomisd($src1$$XMMRegister, $src2$$XMMRegister);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  9394
    emit_cmpfp3(_masm, $dst$$Register);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  9395
  %}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9396
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9397
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9398
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9399
// Compare into -1,0,1 in XMM and memory
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9400
instruct cmpD_regmem(xRegI dst, regD src1, memory src2, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9401
  predicate(UseSSE>=2);
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  9402
  match(Set dst (CmpD3 src1 (LoadD src2)));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9403
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9404
  ins_cost(275);
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  9405
  format %{ "UCOMISD $src1, $src2\n\t"
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  9406
            "MOV     $dst, #-1\n\t"
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  9407
            "JP,s    done\n\t"
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  9408
            "JB,s    done\n\t"
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  9409
            "SETNE   $dst\n\t"
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  9410
            "MOVZB   $dst, $dst\n"
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  9411
    "done:" %}
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  9412
  ins_encode %{
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  9413
    __ ucomisd($src1$$XMMRegister, $src2$$Address);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  9414
    emit_cmpfp3(_masm, $dst$$Register);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
  9415
  %}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9416
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9417
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9418
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9419
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9420
instruct subDPR_reg(regDPR dst, regDPR src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9421
  predicate (UseSSE <=1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9422
  match(Set dst (SubD dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9423
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9424
  format %{ "FLD    $src\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9425
            "DSUBp  $dst,ST" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9426
  opcode(0xDE, 0x5); /* DE E8+i  or DE /5 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9427
  ins_cost(150);
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9428
  ins_encode( Push_Reg_DPR(src),
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9429
              OpcP, RegOpc(dst) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9430
  ins_pipe( fpu_reg_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9431
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9432
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9433
instruct subDPR_reg_round(stackSlotD dst, regDPR src1, regDPR src2) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9434
  predicate (UseSSE <=1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9435
  match(Set dst (RoundDouble (SubD src1 src2)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9436
  ins_cost(250);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9437
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9438
  format %{ "FLD    $src2\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9439
            "DSUB   ST,$src1\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9440
            "FSTP_D $dst\t# D-round" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9441
  opcode(0xD8, 0x5);
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9442
  ins_encode( Push_Reg_DPR(src2),
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9443
              OpcP, RegOpc(src1), Pop_Mem_DPR(dst) );
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9444
  ins_pipe( fpu_mem_reg_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9445
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9446
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9447
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9448
instruct subDPR_reg_mem(regDPR dst, memory src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9449
  predicate (UseSSE <=1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9450
  match(Set dst (SubD dst (LoadD src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9451
  ins_cost(150);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9452
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9453
  format %{ "FLD    $src\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9454
            "DSUBp  $dst,ST" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9455
  opcode(0xDE, 0x5, 0xDD); /* DE C0+i */  /* LoadD  DD /0 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9456
  ins_encode( Opcode(tertiary), RMopc_Mem(0x00,src),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9457
              OpcP, RegOpc(dst) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9458
  ins_pipe( fpu_reg_mem );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9459
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9460
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9461
instruct absDPR_reg(regDPR1 dst, regDPR1 src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9462
  predicate (UseSSE<=1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9463
  match(Set dst (AbsD src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9464
  ins_cost(100);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9465
  format %{ "FABS" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9466
  opcode(0xE1, 0xD9);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9467
  ins_encode( OpcS, OpcP );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9468
  ins_pipe( fpu_reg_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9469
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9470
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9471
instruct negDPR_reg(regDPR1 dst, regDPR1 src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9472
  predicate(UseSSE<=1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9473
  match(Set dst (NegD src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9474
  ins_cost(100);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9475
  format %{ "FCHS" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9476
  opcode(0xE0, 0xD9);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9477
  ins_encode( OpcS, OpcP );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9478
  ins_pipe( fpu_reg_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9479
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9480
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9481
instruct addDPR_reg(regDPR dst, regDPR src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9482
  predicate(UseSSE<=1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9483
  match(Set dst (AddD dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9484
  format %{ "FLD    $src\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9485
            "DADD   $dst,ST" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9486
  size(4);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9487
  ins_cost(150);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9488
  opcode(0xDE, 0x0); /* DE C0+i or DE /0*/
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9489
  ins_encode( Push_Reg_DPR(src),
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9490
              OpcP, RegOpc(dst) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9491
  ins_pipe( fpu_reg_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9492
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9493
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9494
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9495
instruct addDPR_reg_round(stackSlotD dst, regDPR src1, regDPR src2) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9496
  predicate(UseSSE<=1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9497
  match(Set dst (RoundDouble (AddD src1 src2)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9498
  ins_cost(250);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9499
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9500
  format %{ "FLD    $src2\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9501
            "DADD   ST,$src1\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9502
            "FSTP_D $dst\t# D-round" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9503
  opcode(0xD8, 0x0); /* D8 C0+i or D8 /0*/
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9504
  ins_encode( Push_Reg_DPR(src2),
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9505
              OpcP, RegOpc(src1), Pop_Mem_DPR(dst) );
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9506
  ins_pipe( fpu_mem_reg_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9507
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9508
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9509
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9510
instruct addDPR_reg_mem(regDPR dst, memory src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9511
  predicate(UseSSE<=1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9512
  match(Set dst (AddD dst (LoadD src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9513
  ins_cost(150);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9514
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9515
  format %{ "FLD    $src\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9516
            "DADDp  $dst,ST" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9517
  opcode(0xDE, 0x0, 0xDD); /* DE C0+i */  /* LoadD  DD /0 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9518
  ins_encode( Opcode(tertiary), RMopc_Mem(0x00,src),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9519
              OpcP, RegOpc(dst) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9520
  ins_pipe( fpu_reg_mem );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9521
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9522
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9523
// add-to-memory
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9524
instruct addDPR_mem_reg(memory dst, regDPR src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9525
  predicate(UseSSE<=1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9526
  match(Set dst (StoreD dst (RoundDouble (AddD (LoadD dst) src))));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9527
  ins_cost(150);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9528
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9529
  format %{ "FLD_D  $dst\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9530
            "DADD   ST,$src\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9531
            "FST_D  $dst" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9532
  opcode(0xDD, 0x0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9533
  ins_encode( Opcode(0xDD), RMopc_Mem(0x00,dst),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9534
              Opcode(0xD8), RegOpc(src),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9535
              set_instruction_start,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9536
              Opcode(0xDD), RMopc_Mem(0x03,dst) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9537
  ins_pipe( fpu_reg_mem );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9538
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9539
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9540
instruct addDPR_reg_imm1(regDPR dst, immDPR1 con) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9541
  predicate(UseSSE<=1);
7433
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  9542
  match(Set dst (AddD dst con));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9543
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9544
  format %{ "FLD1\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9545
            "DADDp  $dst,ST" %}
7433
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  9546
  ins_encode %{
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  9547
    __ fld1();
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  9548
    __ faddp($dst$$reg);
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  9549
  %}
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  9550
  ins_pipe(fpu_reg);
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  9551
%}
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  9552
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9553
instruct addDPR_reg_imm(regDPR dst, immDPR con) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9554
  predicate(UseSSE<=1 && _kids[1]->_leaf->getd() != 0.0 && _kids[1]->_leaf->getd() != 1.0 );
7433
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  9555
  match(Set dst (AddD dst con));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9556
  ins_cost(200);
7433
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  9557
  format %{ "FLD_D  [$constantaddress]\t# load from constant table: double=$con\n\t"
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9558
            "DADDp  $dst,ST" %}
7433
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  9559
  ins_encode %{
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  9560
    __ fld_d($constantaddress($con));
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  9561
    __ faddp($dst$$reg);
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  9562
  %}
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  9563
  ins_pipe(fpu_reg_mem);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9564
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9565
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9566
instruct addDPR_reg_imm_round(stackSlotD dst, regDPR src, immDPR con) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9567
  predicate(UseSSE<=1 && _kids[0]->_kids[1]->_leaf->getd() != 0.0 && _kids[0]->_kids[1]->_leaf->getd() != 1.0 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9568
  match(Set dst (RoundDouble (AddD src con)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9569
  ins_cost(200);
7433
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  9570
  format %{ "FLD_D  [$constantaddress]\t# load from constant table: double=$con\n\t"
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9571
            "DADD   ST,$src\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9572
            "FSTP_D $dst\t# D-round" %}
7433
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  9573
  ins_encode %{
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  9574
    __ fld_d($constantaddress($con));
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  9575
    __ fadd($src$$reg);
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  9576
    __ fstp_d(Address(rsp, $dst$$disp));
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  9577
  %}
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  9578
  ins_pipe(fpu_mem_reg_con);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9579
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9580
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9581
instruct mulDPR_reg(regDPR dst, regDPR src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9582
  predicate(UseSSE<=1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9583
  match(Set dst (MulD dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9584
  format %{ "FLD    $src\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9585
            "DMULp  $dst,ST" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9586
  opcode(0xDE, 0x1); /* DE C8+i or DE /1*/
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9587
  ins_cost(150);
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9588
  ins_encode( Push_Reg_DPR(src),
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9589
              OpcP, RegOpc(dst) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9590
  ins_pipe( fpu_reg_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9591
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9592
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9593
// Strict FP instruction biases argument before multiply then
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9594
// biases result to avoid double rounding of subnormals.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9595
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9596
// scale arg1 by multiplying arg1 by 2^(-15360)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9597
// load arg2
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9598
// multiply scaled arg1 by arg2
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9599
// rescale product by 2^(15360)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9600
//
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9601
instruct strictfp_mulDPR_reg(regDPR1 dst, regnotDPR1 src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9602
  predicate( UseSSE<=1 && Compile::current()->has_method() && Compile::current()->method()->is_strict() );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9603
  match(Set dst (MulD dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9604
  ins_cost(1);   // Select this instruction for all strict FP double multiplies
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9605
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9606
  format %{ "FLD    StubRoutines::_fpu_subnormal_bias1\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9607
            "DMULp  $dst,ST\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9608
            "FLD    $src\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9609
            "DMULp  $dst,ST\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9610
            "FLD    StubRoutines::_fpu_subnormal_bias2\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9611
            "DMULp  $dst,ST\n\t" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9612
  opcode(0xDE, 0x1); /* DE C8+i or DE /1*/
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9613
  ins_encode( strictfp_bias1(dst),
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9614
              Push_Reg_DPR(src),
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9615
              OpcP, RegOpc(dst),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9616
              strictfp_bias2(dst) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9617
  ins_pipe( fpu_reg_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9618
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9619
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9620
instruct mulDPR_reg_imm(regDPR dst, immDPR con) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9621
  predicate( UseSSE<=1 && _kids[1]->_leaf->getd() != 0.0 && _kids[1]->_leaf->getd() != 1.0 );
7433
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  9622
  match(Set dst (MulD dst con));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9623
  ins_cost(200);
7433
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  9624
  format %{ "FLD_D  [$constantaddress]\t# load from constant table: double=$con\n\t"
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9625
            "DMULp  $dst,ST" %}
7433
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  9626
  ins_encode %{
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  9627
    __ fld_d($constantaddress($con));
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  9628
    __ fmulp($dst$$reg);
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  9629
  %}
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
  9630
  ins_pipe(fpu_reg_mem);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9631
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9632
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9633
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9634
instruct mulDPR_reg_mem(regDPR dst, memory src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9635
  predicate( UseSSE<=1 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9636
  match(Set dst (MulD dst (LoadD src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9637
  ins_cost(200);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9638
  format %{ "FLD_D  $src\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9639
            "DMULp  $dst,ST" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9640
  opcode(0xDE, 0x1, 0xDD); /* DE C8+i or DE /1*/  /* LoadD  DD /0 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9641
  ins_encode( Opcode(tertiary), RMopc_Mem(0x00,src),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9642
              OpcP, RegOpc(dst) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9643
  ins_pipe( fpu_reg_mem );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9644
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9645
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9646
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9647
// Cisc-alternate to reg-reg multiply
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9648
instruct mulDPR_reg_mem_cisc(regDPR dst, regDPR src, memory mem) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9649
  predicate( UseSSE<=1 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9650
  match(Set dst (MulD src (LoadD mem)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9651
  ins_cost(250);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9652
  format %{ "FLD_D  $mem\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9653
            "DMUL   ST,$src\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9654
            "FSTP_D $dst" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9655
  opcode(0xD8, 0x1, 0xD9); /* D8 C8+i */  /* LoadD D9 /0 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9656
  ins_encode( Opcode(tertiary), RMopc_Mem(0x00,mem),
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9657
              OpcReg_FPR(src),
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9658
              Pop_Reg_DPR(dst) );
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9659
  ins_pipe( fpu_reg_reg_mem );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9660
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9661
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9662
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9663
// MACRO3 -- addDPR a mulDPR
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9664
// This instruction is a '2-address' instruction in that the result goes
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9665
// back to src2.  This eliminates a move from the macro; possibly the
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9666
// register allocator will have to add it back (and maybe not).
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9667
instruct addDPR_mulDPR_reg(regDPR src2, regDPR src1, regDPR src0) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9668
  predicate( UseSSE<=1 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9669
  match(Set src2 (AddD (MulD src0 src1) src2));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9670
  format %{ "FLD    $src0\t# ===MACRO3d===\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9671
            "DMUL   ST,$src1\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9672
            "DADDp  $src2,ST" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9673
  ins_cost(250);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9674
  opcode(0xDD); /* LoadD DD /0 */
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9675
  ins_encode( Push_Reg_FPR(src0),
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9676
              FMul_ST_reg(src1),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9677
              FAddP_reg_ST(src2) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9678
  ins_pipe( fpu_reg_reg_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9679
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9680
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9681
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9682
// MACRO3 -- subDPR a mulDPR
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9683
instruct subDPR_mulDPR_reg(regDPR src2, regDPR src1, regDPR src0) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9684
  predicate( UseSSE<=1 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9685
  match(Set src2 (SubD (MulD src0 src1) src2));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9686
  format %{ "FLD    $src0\t# ===MACRO3d===\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9687
            "DMUL   ST,$src1\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9688
            "DSUBRp $src2,ST" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9689
  ins_cost(250);
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9690
  ins_encode( Push_Reg_FPR(src0),
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9691
              FMul_ST_reg(src1),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9692
              Opcode(0xDE), Opc_plus(0xE0,src2));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9693
  ins_pipe( fpu_reg_reg_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9694
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9695
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9696
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9697
instruct divDPR_reg(regDPR dst, regDPR src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9698
  predicate( UseSSE<=1 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9699
  match(Set dst (DivD dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9700
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9701
  format %{ "FLD    $src\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9702
            "FDIVp  $dst,ST" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9703
  opcode(0xDE, 0x7); /* DE F8+i or DE /7*/
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9704
  ins_cost(150);
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9705
  ins_encode( Push_Reg_DPR(src),
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9706
              OpcP, RegOpc(dst) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9707
  ins_pipe( fpu_reg_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9708
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9709
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9710
// Strict FP instruction biases argument before division then
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9711
// biases result, to avoid double rounding of subnormals.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9712
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9713
// scale dividend by multiplying dividend by 2^(-15360)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9714
// load divisor
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9715
// divide scaled dividend by divisor
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9716
// rescale quotient by 2^(15360)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9717
//
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9718
instruct strictfp_divDPR_reg(regDPR1 dst, regnotDPR1 src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9719
  predicate (UseSSE<=1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9720
  match(Set dst (DivD dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9721
  predicate( UseSSE<=1 && Compile::current()->has_method() && Compile::current()->method()->is_strict() );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9722
  ins_cost(01);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9723
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9724
  format %{ "FLD    StubRoutines::_fpu_subnormal_bias1\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9725
            "DMULp  $dst,ST\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9726
            "FLD    $src\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9727
            "FDIVp  $dst,ST\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9728
            "FLD    StubRoutines::_fpu_subnormal_bias2\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9729
            "DMULp  $dst,ST\n\t" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9730
  opcode(0xDE, 0x7); /* DE F8+i or DE /7*/
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9731
  ins_encode( strictfp_bias1(dst),
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9732
              Push_Reg_DPR(src),
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9733
              OpcP, RegOpc(dst),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9734
              strictfp_bias2(dst) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9735
  ins_pipe( fpu_reg_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9736
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9737
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9738
instruct divDPR_reg_round(stackSlotD dst, regDPR src1, regDPR src2) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9739
  predicate( UseSSE<=1 && !(Compile::current()->has_method() && Compile::current()->method()->is_strict()) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9740
  match(Set dst (RoundDouble (DivD src1 src2)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9741
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9742
  format %{ "FLD    $src1\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9743
            "FDIV   ST,$src2\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9744
            "FSTP_D $dst\t# D-round" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9745
  opcode(0xD8, 0x6); /* D8 F0+i or D8 /6 */
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9746
  ins_encode( Push_Reg_DPR(src1),
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9747
              OpcP, RegOpc(src2), Pop_Mem_DPR(dst) );
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9748
  ins_pipe( fpu_mem_reg_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9749
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9750
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9751
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9752
instruct modDPR_reg(regDPR dst, regDPR src, eAXRegI rax, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9753
  predicate(UseSSE<=1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9754
  match(Set dst (ModD dst src));
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9755
  effect(KILL rax, KILL cr); // emitModDPR() uses EAX and EFLAGS
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9756
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9757
  format %{ "DMOD   $dst,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9758
  ins_cost(250);
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9759
  ins_encode(Push_Reg_Mod_DPR(dst, src),
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9760
              emitModDPR(),
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9761
              Push_Result_Mod_DPR(src),
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9762
              Pop_Reg_DPR(dst));
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9763
  ins_pipe( pipe_slow );
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9764
%}
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9765
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9766
instruct modD_reg(regD dst, regD src0, regD src1, eAXRegI rax, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9767
  predicate(UseSSE>=2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9768
  match(Set dst (ModD src0 src1));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9769
  effect(KILL rax, KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9770
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9771
  format %{ "SUB    ESP,8\t # DMOD\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9772
          "\tMOVSD  [ESP+0],$src1\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9773
          "\tFLD_D  [ESP+0]\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9774
          "\tMOVSD  [ESP+0],$src0\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9775
          "\tFLD_D  [ESP+0]\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9776
     "loop:\tFPREM\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9777
          "\tFWAIT\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9778
          "\tFNSTSW AX\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9779
          "\tSAHF\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9780
          "\tJP     loop\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9781
          "\tFSTP_D [ESP+0]\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9782
          "\tMOVSD  $dst,[ESP+0]\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9783
          "\tADD    ESP,8\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9784
          "\tFSTP   ST0\t # Restore FPU Stack"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9785
    %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9786
  ins_cost(250);
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9787
  ins_encode( Push_ModD_encoding(src0, src1), emitModDPR(), Push_ResultD(dst), PopFPU);
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9788
  ins_pipe( pipe_slow );
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9789
%}
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9790
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9791
instruct sinDPR_reg(regDPR1 dst, regDPR1 src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9792
  predicate (UseSSE<=1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9793
  match(Set dst (SinD src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9794
  ins_cost(1800);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9795
  format %{ "DSIN   $dst" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9796
  opcode(0xD9, 0xFE);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9797
  ins_encode( OpcP, OpcS );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9798
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9799
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9800
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9801
instruct sinD_reg(regD dst, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9802
  predicate (UseSSE>=2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9803
  match(Set dst (SinD dst));
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9804
  effect(KILL cr); // Push_{Src|Result}D() uses "{SUB|ADD} ESP,8"
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9805
  ins_cost(1800);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9806
  format %{ "DSIN   $dst" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9807
  opcode(0xD9, 0xFE);
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9808
  ins_encode( Push_SrcD(dst), OpcP, OpcS, Push_ResultD(dst) );
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9809
  ins_pipe( pipe_slow );
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9810
%}
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9811
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9812
instruct cosDPR_reg(regDPR1 dst, regDPR1 src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9813
  predicate (UseSSE<=1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9814
  match(Set dst (CosD src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9815
  ins_cost(1800);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9816
  format %{ "DCOS   $dst" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9817
  opcode(0xD9, 0xFF);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9818
  ins_encode( OpcP, OpcS );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9819
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9820
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9821
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9822
instruct cosD_reg(regD dst, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9823
  predicate (UseSSE>=2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9824
  match(Set dst (CosD dst));
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9825
  effect(KILL cr); // Push_{Src|Result}D() uses "{SUB|ADD} ESP,8"
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9826
  ins_cost(1800);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9827
  format %{ "DCOS   $dst" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9828
  opcode(0xD9, 0xFF);
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9829
  ins_encode( Push_SrcD(dst), OpcP, OpcS, Push_ResultD(dst) );
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9830
  ins_pipe( pipe_slow );
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9831
%}
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9832
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9833
instruct tanDPR_reg(regDPR1 dst, regDPR1 src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9834
  predicate (UseSSE<=1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9835
  match(Set dst(TanD src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9836
  format %{ "DTAN   $dst" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9837
  ins_encode( Opcode(0xD9), Opcode(0xF2),    // fptan
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9838
              Opcode(0xDD), Opcode(0xD8));   // fstp st
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9839
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9840
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9841
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9842
instruct tanD_reg(regD dst, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9843
  predicate (UseSSE>=2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9844
  match(Set dst(TanD dst));
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9845
  effect(KILL cr); // Push_{Src|Result}D() uses "{SUB|ADD} ESP,8"
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9846
  format %{ "DTAN   $dst" %}
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9847
  ins_encode( Push_SrcD(dst),
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9848
              Opcode(0xD9), Opcode(0xF2),    // fptan
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9849
              Opcode(0xDD), Opcode(0xD8),   // fstp st
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9850
              Push_ResultD(dst) );
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9851
  ins_pipe( pipe_slow );
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9852
%}
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9853
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9854
instruct atanDPR_reg(regDPR dst, regDPR src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9855
  predicate (UseSSE<=1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9856
  match(Set dst(AtanD dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9857
  format %{ "DATA   $dst,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9858
  opcode(0xD9, 0xF3);
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9859
  ins_encode( Push_Reg_DPR(src),
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9860
              OpcP, OpcS, RegOpc(dst) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9861
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9862
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9863
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9864
instruct atanD_reg(regD dst, regD src, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9865
  predicate (UseSSE>=2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9866
  match(Set dst(AtanD dst src));
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9867
  effect(KILL cr); // Push_{Src|Result}D() uses "{SUB|ADD} ESP,8"
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9868
  format %{ "DATA   $dst,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9869
  opcode(0xD9, 0xF3);
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9870
  ins_encode( Push_SrcD(src),
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9871
              OpcP, OpcS, Push_ResultD(dst) );
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9872
  ins_pipe( pipe_slow );
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9873
%}
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9874
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9875
instruct sqrtDPR_reg(regDPR dst, regDPR src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9876
  predicate (UseSSE<=1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9877
  match(Set dst (SqrtD src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9878
  format %{ "DSQRT  $dst,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9879
  opcode(0xFA, 0xD9);
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9880
  ins_encode( Push_Reg_DPR(src),
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9881
              OpcS, OpcP, Pop_Reg_DPR(dst) );
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9882
  ins_pipe( pipe_slow );
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9883
%}
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9884
12739
09f26b73ae66 7133857: exp() and pow() should use the x87 ISA on x86
roland
parents: 12113
diff changeset
  9885
instruct powDPR_reg(regDPR X, regDPR1 Y, eAXRegI rax, eDXRegI rdx, eCXRegI rcx, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9886
  predicate (UseSSE<=1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9887
  match(Set Y (PowD X Y));  // Raise X to the Yth power
12739
09f26b73ae66 7133857: exp() and pow() should use the x87 ISA on x86
roland
parents: 12113
diff changeset
  9888
  effect(KILL rax, KILL rdx, KILL rcx, KILL cr);
09f26b73ae66 7133857: exp() and pow() should use the x87 ISA on x86
roland
parents: 12113
diff changeset
  9889
  format %{ "fast_pow $X $Y -> $Y  // KILL $rax, $rcx, $rdx" %}
09f26b73ae66 7133857: exp() and pow() should use the x87 ISA on x86
roland
parents: 12113
diff changeset
  9890
  ins_encode %{
09f26b73ae66 7133857: exp() and pow() should use the x87 ISA on x86
roland
parents: 12113
diff changeset
  9891
    __ subptr(rsp, 8);
09f26b73ae66 7133857: exp() and pow() should use the x87 ISA on x86
roland
parents: 12113
diff changeset
  9892
    __ fld_s($X$$reg - 1);
09f26b73ae66 7133857: exp() and pow() should use the x87 ISA on x86
roland
parents: 12113
diff changeset
  9893
    __ fast_pow();
09f26b73ae66 7133857: exp() and pow() should use the x87 ISA on x86
roland
parents: 12113
diff changeset
  9894
    __ addptr(rsp, 8);
09f26b73ae66 7133857: exp() and pow() should use the x87 ISA on x86
roland
parents: 12113
diff changeset
  9895
  %}
09f26b73ae66 7133857: exp() and pow() should use the x87 ISA on x86
roland
parents: 12113
diff changeset
  9896
  ins_pipe( pipe_slow );
09f26b73ae66 7133857: exp() and pow() should use the x87 ISA on x86
roland
parents: 12113
diff changeset
  9897
%}
09f26b73ae66 7133857: exp() and pow() should use the x87 ISA on x86
roland
parents: 12113
diff changeset
  9898
09f26b73ae66 7133857: exp() and pow() should use the x87 ISA on x86
roland
parents: 12113
diff changeset
  9899
instruct powD_reg(regD dst, regD src0, regD src1, eAXRegI rax, eDXRegI rdx, eCXRegI rcx, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9900
  predicate (UseSSE>=2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9901
  match(Set dst (PowD src0 src1));  // Raise src0 to the src1'th power
12739
09f26b73ae66 7133857: exp() and pow() should use the x87 ISA on x86
roland
parents: 12113
diff changeset
  9902
  effect(KILL rax, KILL rdx, KILL rcx, KILL cr);
09f26b73ae66 7133857: exp() and pow() should use the x87 ISA on x86
roland
parents: 12113
diff changeset
  9903
  format %{ "fast_pow $src0 $src1 -> $dst  // KILL $rax, $rcx, $rdx" %}
09f26b73ae66 7133857: exp() and pow() should use the x87 ISA on x86
roland
parents: 12113
diff changeset
  9904
  ins_encode %{
09f26b73ae66 7133857: exp() and pow() should use the x87 ISA on x86
roland
parents: 12113
diff changeset
  9905
    __ subptr(rsp, 8);
09f26b73ae66 7133857: exp() and pow() should use the x87 ISA on x86
roland
parents: 12113
diff changeset
  9906
    __ movdbl(Address(rsp, 0), $src1$$XMMRegister);
09f26b73ae66 7133857: exp() and pow() should use the x87 ISA on x86
roland
parents: 12113
diff changeset
  9907
    __ fld_d(Address(rsp, 0));
09f26b73ae66 7133857: exp() and pow() should use the x87 ISA on x86
roland
parents: 12113
diff changeset
  9908
    __ movdbl(Address(rsp, 0), $src0$$XMMRegister);
09f26b73ae66 7133857: exp() and pow() should use the x87 ISA on x86
roland
parents: 12113
diff changeset
  9909
    __ fld_d(Address(rsp, 0));
09f26b73ae66 7133857: exp() and pow() should use the x87 ISA on x86
roland
parents: 12113
diff changeset
  9910
    __ fast_pow();
09f26b73ae66 7133857: exp() and pow() should use the x87 ISA on x86
roland
parents: 12113
diff changeset
  9911
    __ fstp_d(Address(rsp, 0));
09f26b73ae66 7133857: exp() and pow() should use the x87 ISA on x86
roland
parents: 12113
diff changeset
  9912
    __ movdbl($dst$$XMMRegister, Address(rsp, 0));
09f26b73ae66 7133857: exp() and pow() should use the x87 ISA on x86
roland
parents: 12113
diff changeset
  9913
    __ addptr(rsp, 8);
09f26b73ae66 7133857: exp() and pow() should use the x87 ISA on x86
roland
parents: 12113
diff changeset
  9914
  %}
09f26b73ae66 7133857: exp() and pow() should use the x87 ISA on x86
roland
parents: 12113
diff changeset
  9915
  ins_pipe( pipe_slow );
09f26b73ae66 7133857: exp() and pow() should use the x87 ISA on x86
roland
parents: 12113
diff changeset
  9916
%}
09f26b73ae66 7133857: exp() and pow() should use the x87 ISA on x86
roland
parents: 12113
diff changeset
  9917
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9918
instruct log10DPR_reg(regDPR1 dst, regDPR1 src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9919
  predicate (UseSSE<=1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9920
  // The source Double operand on FPU stack
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9921
  match(Set dst (Log10D src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9922
  // fldlg2       ; push log_10(2) on the FPU stack; full 80-bit number
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9923
  // fxch         ; swap ST(0) with ST(1)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9924
  // fyl2x        ; compute log_10(2) * log_2(x)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9925
  format %{ "FLDLG2 \t\t\t#Log10\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9926
            "FXCH   \n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9927
            "FYL2X  \t\t\t# Q=Log10*Log_2(x)"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9928
         %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9929
  ins_encode( Opcode(0xD9), Opcode(0xEC),   // fldlg2
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9930
              Opcode(0xD9), Opcode(0xC9),   // fxch
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9931
              Opcode(0xD9), Opcode(0xF1));  // fyl2x
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9932
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9933
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9934
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9935
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9936
instruct log10D_reg(regD dst, regD src, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9937
  predicate (UseSSE>=2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9938
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9939
  match(Set dst (Log10D src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9940
  // fldlg2       ; push log_10(2) on the FPU stack; full 80-bit number
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9941
  // fyl2x        ; compute log_10(2) * log_2(x)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9942
  format %{ "FLDLG2 \t\t\t#Log10\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9943
            "FYL2X  \t\t\t# Q=Log10*Log_2(x)"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9944
         %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9945
  ins_encode( Opcode(0xD9), Opcode(0xEC),   // fldlg2
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9946
              Push_SrcD(src),
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9947
              Opcode(0xD9), Opcode(0xF1),   // fyl2x
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9948
              Push_ResultD(dst));
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9949
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9950
  ins_pipe( pipe_slow );
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9951
%}
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9952
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9953
//-------------Float Instructions-------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9954
// Float Math
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9955
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9956
// Code for float compare:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9957
//     fcompp();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9958
//     fwait(); fnstsw_ax();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9959
//     sahf();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9960
//     movl(dst, unordered_result);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9961
//     jcc(Assembler::parity, exit);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9962
//     movl(dst, less_result);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9963
//     jcc(Assembler::below, exit);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9964
//     movl(dst, equal_result);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9965
//     jcc(Assembler::equal, exit);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9966
//     movl(dst, greater_result);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9967
//   exit:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9968
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9969
// P6 version of float compare, sets condition codes in EFLAGS
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9970
instruct cmpFPR_cc_P6(eFlagsRegU cr, regFPR src1, regFPR src2, eAXRegI rax) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9971
  predicate(VM_Version::supports_cmov() && UseSSE == 0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9972
  match(Set cr (CmpF src1 src2));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9973
  effect(KILL rax);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9974
  ins_cost(150);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9975
  format %{ "FLD    $src1\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9976
            "FUCOMIP ST,$src2  // P6 instruction\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9977
            "JNP    exit\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9978
            "MOV    ah,1       // saw a NaN, set CF (treat as LT)\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9979
            "SAHF\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9980
     "exit:\tNOP               // avoid branch to branch" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9981
  opcode(0xDF, 0x05); /* DF E8+i or DF /5 */
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9982
  ins_encode( Push_Reg_DPR(src1),
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9983
              OpcP, RegOpc(src2),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9984
              cmpF_P6_fixup );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9985
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9986
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9987
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9988
instruct cmpFPR_cc_P6CF(eFlagsRegUCF cr, regFPR src1, regFPR src2) %{
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  9989
  predicate(VM_Version::supports_cmov() && UseSSE == 0);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  9990
  match(Set cr (CmpF src1 src2));
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  9991
  ins_cost(100);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  9992
  format %{ "FLD    $src1\n\t"
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  9993
            "FUCOMIP ST,$src2  // P6 instruction" %}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  9994
  opcode(0xDF, 0x05); /* DF E8+i or DF /5 */
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
  9995
  ins_encode( Push_Reg_DPR(src1),
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  9996
              OpcP, RegOpc(src2));
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  9997
  ins_pipe( pipe_slow );
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  9998
%}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  9999
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10000
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10001
// Compare & branch
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10002
instruct cmpFPR_cc(eFlagsRegU cr, regFPR src1, regFPR src2, eAXRegI rax) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10003
  predicate(UseSSE == 0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10004
  match(Set cr (CmpF src1 src2));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10005
  effect(KILL rax);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10006
  ins_cost(200);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10007
  format %{ "FLD    $src1\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10008
            "FCOMp  $src2\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10009
            "FNSTSW AX\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10010
            "TEST   AX,0x400\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10011
            "JZ,s   flags\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10012
            "MOV    AH,1\t# unordered treat as LT\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10013
    "flags:\tSAHF" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10014
  opcode(0xD8, 0x3); /* D8 D8+i or D8 /3 */
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10015
  ins_encode( Push_Reg_DPR(src1),
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10016
              OpcP, RegOpc(src2),
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10017
              fpu_flags);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10018
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10019
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10020
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10021
// Compare vs zero into -1,0,1
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
 10022
instruct cmpFPR_0(rRegI dst, regFPR src1, immFPR0 zero, eAXRegI rax, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10023
  predicate(UseSSE == 0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10024
  match(Set dst (CmpF3 src1 zero));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10025
  effect(KILL cr, KILL rax);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10026
  ins_cost(280);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10027
  format %{ "FTSTF  $dst,$src1" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10028
  opcode(0xE4, 0xD9);
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10029
  ins_encode( Push_Reg_DPR(src1),
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10030
              OpcS, OpcP, PopFPU,
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10031
              CmpF_Result(dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10032
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10033
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10034
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10035
// Compare into -1,0,1
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
 10036
instruct cmpFPR_reg(rRegI dst, regFPR src1, regFPR src2, eAXRegI rax, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10037
  predicate(UseSSE == 0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10038
  match(Set dst (CmpF3 src1 src2));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10039
  effect(KILL cr, KILL rax);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10040
  ins_cost(300);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10041
  format %{ "FCMPF  $dst,$src1,$src2" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10042
  opcode(0xD8, 0x3); /* D8 D8+i or D8 /3 */
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10043
  ins_encode( Push_Reg_DPR(src1),
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10044
              OpcP, RegOpc(src2),
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10045
              CmpF_Result(dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10046
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10047
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10048
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10049
// float compare and set condition codes in EFLAGS by XMM regs
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10050
instruct cmpF_cc(eFlagsRegU cr, regF src1, regF src2) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10051
  predicate(UseSSE>=1);
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10052
  match(Set cr (CmpF src1 src2));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10053
  ins_cost(145);
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10054
  format %{ "UCOMISS $src1,$src2\n\t"
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10055
            "JNP,s   exit\n\t"
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10056
            "PUSHF\t# saw NaN, set CF\n\t"
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10057
            "AND     [rsp], #0xffffff2b\n\t"
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10058
            "POPF\n"
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10059
    "exit:" %}
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10060
  ins_encode %{
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10061
    __ ucomiss($src1$$XMMRegister, $src2$$XMMRegister);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10062
    emit_cmpfp_fixup(_masm);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10063
  %}
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10064
  ins_pipe( pipe_slow );
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10065
%}
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10066
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10067
instruct cmpF_ccCF(eFlagsRegUCF cr, regF src1, regF src2) %{
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 10068
  predicate(UseSSE>=1);
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10069
  match(Set cr (CmpF src1 src2));
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 10070
  ins_cost(100);
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10071
  format %{ "UCOMISS $src1,$src2" %}
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10072
  ins_encode %{
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10073
    __ ucomiss($src1$$XMMRegister, $src2$$XMMRegister);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10074
  %}
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 10075
  ins_pipe( pipe_slow );
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 10076
%}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 10077
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10078
// float compare and set condition codes in EFLAGS by XMM regs
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10079
instruct cmpF_ccmem(eFlagsRegU cr, regF src1, memory src2) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10080
  predicate(UseSSE>=1);
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10081
  match(Set cr (CmpF src1 (LoadF src2)));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10082
  ins_cost(165);
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10083
  format %{ "UCOMISS $src1,$src2\n\t"
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10084
            "JNP,s   exit\n\t"
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10085
            "PUSHF\t# saw NaN, set CF\n\t"
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10086
            "AND     [rsp], #0xffffff2b\n\t"
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10087
            "POPF\n"
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10088
    "exit:" %}
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10089
  ins_encode %{
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10090
    __ ucomiss($src1$$XMMRegister, $src2$$Address);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10091
    emit_cmpfp_fixup(_masm);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10092
  %}
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10093
  ins_pipe( pipe_slow );
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10094
%}
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10095
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10096
instruct cmpF_ccmemCF(eFlagsRegUCF cr, regF src1, memory src2) %{
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 10097
  predicate(UseSSE>=1);
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10098
  match(Set cr (CmpF src1 (LoadF src2)));
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 10099
  ins_cost(100);
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10100
  format %{ "UCOMISS $src1,$src2" %}
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10101
  ins_encode %{
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10102
    __ ucomiss($src1$$XMMRegister, $src2$$Address);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10103
  %}
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 10104
  ins_pipe( pipe_slow );
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 10105
%}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 10106
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10107
// Compare into -1,0,1 in XMM
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10108
instruct cmpF_reg(xRegI dst, regF src1, regF src2, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10109
  predicate(UseSSE>=1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10110
  match(Set dst (CmpF3 src1 src2));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10111
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10112
  ins_cost(255);
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10113
  format %{ "UCOMISS $src1, $src2\n\t"
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10114
            "MOV     $dst, #-1\n\t"
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10115
            "JP,s    done\n\t"
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10116
            "JB,s    done\n\t"
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10117
            "SETNE   $dst\n\t"
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10118
            "MOVZB   $dst, $dst\n"
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10119
    "done:" %}
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10120
  ins_encode %{
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10121
    __ ucomiss($src1$$XMMRegister, $src2$$XMMRegister);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10122
    emit_cmpfp3(_masm, $dst$$Register);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10123
  %}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10124
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10125
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10126
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10127
// Compare into -1,0,1 in XMM and memory
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10128
instruct cmpF_regmem(xRegI dst, regF src1, memory src2, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10129
  predicate(UseSSE>=1);
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10130
  match(Set dst (CmpF3 src1 (LoadF src2)));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10131
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10132
  ins_cost(275);
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10133
  format %{ "UCOMISS $src1, $src2\n\t"
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10134
            "MOV     $dst, #-1\n\t"
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10135
            "JP,s    done\n\t"
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10136
            "JB,s    done\n\t"
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10137
            "SETNE   $dst\n\t"
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10138
            "MOVZB   $dst, $dst\n"
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10139
    "done:" %}
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10140
  ins_encode %{
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10141
    __ ucomiss($src1$$XMMRegister, $src2$$Address);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10142
    emit_cmpfp3(_masm, $dst$$Register);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10143
  %}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10144
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10145
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10146
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10147
// Spill to obtain 24-bit precision
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10148
instruct subFPR24_reg(stackSlotF dst, regFPR src1, regFPR src2) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10149
  predicate(UseSSE==0 && Compile::current()->select_24_bit_instr());
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10150
  match(Set dst (SubF src1 src2));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10151
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10152
  format %{ "FSUB   $dst,$src1 - $src2" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10153
  opcode(0xD8, 0x4); /* D8 E0+i or D8 /4 mod==0x3 ;; result in TOS */
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10154
  ins_encode( Push_Reg_FPR(src1),
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10155
              OpcReg_FPR(src2),
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10156
              Pop_Mem_FPR(dst) );
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10157
  ins_pipe( fpu_mem_reg_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10158
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10159
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10160
// This instruction does not round to 24-bits
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10161
instruct subFPR_reg(regFPR dst, regFPR src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10162
  predicate(UseSSE==0 && !Compile::current()->select_24_bit_instr());
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10163
  match(Set dst (SubF dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10164
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10165
  format %{ "FSUB   $dst,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10166
  opcode(0xDE, 0x5); /* DE E8+i  or DE /5 */
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10167
  ins_encode( Push_Reg_FPR(src),
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10168
              OpcP, RegOpc(dst) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10169
  ins_pipe( fpu_reg_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10170
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10171
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10172
// Spill to obtain 24-bit precision
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10173
instruct addFPR24_reg(stackSlotF dst, regFPR src1, regFPR src2) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10174
  predicate(UseSSE==0 && Compile::current()->select_24_bit_instr());
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10175
  match(Set dst (AddF src1 src2));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10176
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10177
  format %{ "FADD   $dst,$src1,$src2" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10178
  opcode(0xD8, 0x0); /* D8 C0+i */
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10179
  ins_encode( Push_Reg_FPR(src2),
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10180
              OpcReg_FPR(src1),
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10181
              Pop_Mem_FPR(dst) );
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10182
  ins_pipe( fpu_mem_reg_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10183
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10184
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10185
// This instruction does not round to 24-bits
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10186
instruct addFPR_reg(regFPR dst, regFPR src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10187
  predicate(UseSSE==0 && !Compile::current()->select_24_bit_instr());
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10188
  match(Set dst (AddF dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10189
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10190
  format %{ "FLD    $src\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10191
            "FADDp  $dst,ST" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10192
  opcode(0xDE, 0x0); /* DE C0+i or DE /0*/
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10193
  ins_encode( Push_Reg_FPR(src),
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10194
              OpcP, RegOpc(dst) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10195
  ins_pipe( fpu_reg_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10196
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10197
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10198
instruct absFPR_reg(regFPR1 dst, regFPR1 src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10199
  predicate(UseSSE==0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10200
  match(Set dst (AbsF src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10201
  ins_cost(100);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10202
  format %{ "FABS" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10203
  opcode(0xE1, 0xD9);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10204
  ins_encode( OpcS, OpcP );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10205
  ins_pipe( fpu_reg_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10206
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10207
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10208
instruct negFPR_reg(regFPR1 dst, regFPR1 src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10209
  predicate(UseSSE==0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10210
  match(Set dst (NegF src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10211
  ins_cost(100);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10212
  format %{ "FCHS" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10213
  opcode(0xE0, 0xD9);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10214
  ins_encode( OpcS, OpcP );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10215
  ins_pipe( fpu_reg_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10216
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10217
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10218
// Cisc-alternate to addFPR_reg
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10219
// Spill to obtain 24-bit precision
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10220
instruct addFPR24_reg_mem(stackSlotF dst, regFPR src1, memory src2) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10221
  predicate(UseSSE==0 && Compile::current()->select_24_bit_instr());
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10222
  match(Set dst (AddF src1 (LoadF src2)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10223
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10224
  format %{ "FLD    $src2\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10225
            "FADD   ST,$src1\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10226
            "FSTP_S $dst" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10227
  opcode(0xD8, 0x0, 0xD9); /* D8 C0+i */  /* LoadF  D9 /0 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10228
  ins_encode( Opcode(tertiary), RMopc_Mem(0x00,src2),
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10229
              OpcReg_FPR(src1),
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10230
              Pop_Mem_FPR(dst) );
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10231
  ins_pipe( fpu_mem_reg_mem );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10232
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10233
//
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10234
// Cisc-alternate to addFPR_reg
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10235
// This instruction does not round to 24-bits
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10236
instruct addFPR_reg_mem(regFPR dst, memory src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10237
  predicate(UseSSE==0 && !Compile::current()->select_24_bit_instr());
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10238
  match(Set dst (AddF dst (LoadF src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10239
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10240
  format %{ "FADD   $dst,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10241
  opcode(0xDE, 0x0, 0xD9); /* DE C0+i or DE /0*/  /* LoadF  D9 /0 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10242
  ins_encode( Opcode(tertiary), RMopc_Mem(0x00,src),
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10243
              OpcP, RegOpc(dst) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10244
  ins_pipe( fpu_reg_mem );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10245
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10246
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10247
// // Following two instructions for _222_mpegaudio
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10248
// Spill to obtain 24-bit precision
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10249
instruct addFPR24_mem_reg(stackSlotF dst, regFPR src2, memory src1 ) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10250
  predicate(UseSSE==0 && Compile::current()->select_24_bit_instr());
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10251
  match(Set dst (AddF src1 src2));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10252
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10253
  format %{ "FADD   $dst,$src1,$src2" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10254
  opcode(0xD8, 0x0, 0xD9); /* D8 C0+i */  /* LoadF  D9 /0 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10255
  ins_encode( Opcode(tertiary), RMopc_Mem(0x00,src1),
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10256
              OpcReg_FPR(src2),
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10257
              Pop_Mem_FPR(dst) );
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10258
  ins_pipe( fpu_mem_reg_mem );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10259
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10260
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10261
// Cisc-spill variant
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10262
// Spill to obtain 24-bit precision
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10263
instruct addFPR24_mem_cisc(stackSlotF dst, memory src1, memory src2) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10264
  predicate(UseSSE==0 && Compile::current()->select_24_bit_instr());
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10265
  match(Set dst (AddF src1 (LoadF src2)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10266
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10267
  format %{ "FADD   $dst,$src1,$src2 cisc" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10268
  opcode(0xD8, 0x0, 0xD9); /* D8 C0+i */  /* LoadF  D9 /0 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10269
  ins_encode( Opcode(tertiary), RMopc_Mem(0x00,src2),
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10270
              set_instruction_start,
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10271
              OpcP, RMopc_Mem(secondary,src1),
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10272
              Pop_Mem_FPR(dst) );
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10273
  ins_pipe( fpu_mem_mem_mem );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10274
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10275
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10276
// Spill to obtain 24-bit precision
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10277
instruct addFPR24_mem_mem(stackSlotF dst, memory src1, memory src2) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10278
  predicate(UseSSE==0 && Compile::current()->select_24_bit_instr());
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10279
  match(Set dst (AddF src1 src2));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10280
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10281
  format %{ "FADD   $dst,$src1,$src2" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10282
  opcode(0xD8, 0x0, 0xD9); /* D8 /0 */  /* LoadF  D9 /0 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10283
  ins_encode( Opcode(tertiary), RMopc_Mem(0x00,src2),
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10284
              set_instruction_start,
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10285
              OpcP, RMopc_Mem(secondary,src1),
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10286
              Pop_Mem_FPR(dst) );
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10287
  ins_pipe( fpu_mem_mem_mem );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10288
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10289
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10290
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10291
// Spill to obtain 24-bit precision
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10292
instruct addFPR24_reg_imm(stackSlotF dst, regFPR src, immFPR con) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10293
  predicate(UseSSE==0 && Compile::current()->select_24_bit_instr());
7433
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
 10294
  match(Set dst (AddF src con));
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
 10295
  format %{ "FLD    $src\n\t"
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
 10296
            "FADD_S [$constantaddress]\t# load from constant table: float=$con\n\t"
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10297
            "FSTP_S $dst"  %}
7433
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
 10298
  ins_encode %{
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
 10299
    __ fld_s($src$$reg - 1);  // FLD ST(i-1)
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
 10300
    __ fadd_s($constantaddress($con));
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
 10301
    __ fstp_s(Address(rsp, $dst$$disp));
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
 10302
  %}
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
 10303
  ins_pipe(fpu_mem_reg_con);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10304
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10305
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10306
// This instruction does not round to 24-bits
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10307
instruct addFPR_reg_imm(regFPR dst, regFPR src, immFPR con) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10308
  predicate(UseSSE==0 && !Compile::current()->select_24_bit_instr());
7433
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
 10309
  match(Set dst (AddF src con));
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
 10310
  format %{ "FLD    $src\n\t"
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
 10311
            "FADD_S [$constantaddress]\t# load from constant table: float=$con\n\t"
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
 10312
            "FSTP   $dst"  %}
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
 10313
  ins_encode %{
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
 10314
    __ fld_s($src$$reg - 1);  // FLD ST(i-1)
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
 10315
    __ fadd_s($constantaddress($con));
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
 10316
    __ fstp_d($dst$$reg);
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
 10317
  %}
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
 10318
  ins_pipe(fpu_reg_reg_con);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10319
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10320
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10321
// Spill to obtain 24-bit precision
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10322
instruct mulFPR24_reg(stackSlotF dst, regFPR src1, regFPR src2) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10323
  predicate(UseSSE==0 && Compile::current()->select_24_bit_instr());
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10324
  match(Set dst (MulF src1 src2));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10325
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10326
  format %{ "FLD    $src1\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10327
            "FMUL   $src2\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10328
            "FSTP_S $dst"  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10329
  opcode(0xD8, 0x1); /* D8 C8+i or D8 /1 ;; result in TOS */
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10330
  ins_encode( Push_Reg_FPR(src1),
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10331
              OpcReg_FPR(src2),
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10332
              Pop_Mem_FPR(dst) );
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10333
  ins_pipe( fpu_mem_reg_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10334
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10335
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10336
// This instruction does not round to 24-bits
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10337
instruct mulFPR_reg(regFPR dst, regFPR src1, regFPR src2) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10338
  predicate(UseSSE==0 && !Compile::current()->select_24_bit_instr());
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10339
  match(Set dst (MulF src1 src2));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10340
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10341
  format %{ "FLD    $src1\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10342
            "FMUL   $src2\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10343
            "FSTP_S $dst"  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10344
  opcode(0xD8, 0x1); /* D8 C8+i */
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10345
  ins_encode( Push_Reg_FPR(src2),
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10346
              OpcReg_FPR(src1),
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10347
              Pop_Reg_FPR(dst) );
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10348
  ins_pipe( fpu_reg_reg_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10349
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10350
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10351
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10352
// Spill to obtain 24-bit precision
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10353
// Cisc-alternate to reg-reg multiply
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10354
instruct mulFPR24_reg_mem(stackSlotF dst, regFPR src1, memory src2) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10355
  predicate(UseSSE==0 && Compile::current()->select_24_bit_instr());
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10356
  match(Set dst (MulF src1 (LoadF src2)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10357
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10358
  format %{ "FLD_S  $src2\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10359
            "FMUL   $src1\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10360
            "FSTP_S $dst"  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10361
  opcode(0xD8, 0x1, 0xD9); /* D8 C8+i or DE /1*/  /* LoadF D9 /0 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10362
  ins_encode( Opcode(tertiary), RMopc_Mem(0x00,src2),
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10363
              OpcReg_FPR(src1),
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10364
              Pop_Mem_FPR(dst) );
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10365
  ins_pipe( fpu_mem_reg_mem );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10366
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10367
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10368
// This instruction does not round to 24-bits
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10369
// Cisc-alternate to reg-reg multiply
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10370
instruct mulFPR_reg_mem(regFPR dst, regFPR src1, memory src2) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10371
  predicate(UseSSE==0 && !Compile::current()->select_24_bit_instr());
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10372
  match(Set dst (MulF src1 (LoadF src2)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10373
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10374
  format %{ "FMUL   $dst,$src1,$src2" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10375
  opcode(0xD8, 0x1, 0xD9); /* D8 C8+i */  /* LoadF D9 /0 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10376
  ins_encode( Opcode(tertiary), RMopc_Mem(0x00,src2),
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10377
              OpcReg_FPR(src1),
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10378
              Pop_Reg_FPR(dst) );
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10379
  ins_pipe( fpu_reg_reg_mem );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10380
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10381
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10382
// Spill to obtain 24-bit precision
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10383
instruct mulFPR24_mem_mem(stackSlotF dst, memory src1, memory src2) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10384
  predicate(UseSSE==0 && Compile::current()->select_24_bit_instr());
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10385
  match(Set dst (MulF src1 src2));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10386
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10387
  format %{ "FMUL   $dst,$src1,$src2" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10388
  opcode(0xD8, 0x1, 0xD9); /* D8 /1 */  /* LoadF D9 /0 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10389
  ins_encode( Opcode(tertiary), RMopc_Mem(0x00,src2),
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10390
              set_instruction_start,
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10391
              OpcP, RMopc_Mem(secondary,src1),
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10392
              Pop_Mem_FPR(dst) );
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10393
  ins_pipe( fpu_mem_mem_mem );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10394
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10395
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10396
// Spill to obtain 24-bit precision
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10397
instruct mulFPR24_reg_imm(stackSlotF dst, regFPR src, immFPR con) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10398
  predicate(UseSSE==0 && Compile::current()->select_24_bit_instr());
7433
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
 10399
  match(Set dst (MulF src con));
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
 10400
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
 10401
  format %{ "FLD    $src\n\t"
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
 10402
            "FMUL_S [$constantaddress]\t# load from constant table: float=$con\n\t"
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
 10403
            "FSTP_S $dst"  %}
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
 10404
  ins_encode %{
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
 10405
    __ fld_s($src$$reg - 1);  // FLD ST(i-1)
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
 10406
    __ fmul_s($constantaddress($con));
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
 10407
    __ fstp_s(Address(rsp, $dst$$disp));
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
 10408
  %}
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
 10409
  ins_pipe(fpu_mem_reg_con);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10410
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10411
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10412
// This instruction does not round to 24-bits
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10413
instruct mulFPR_reg_imm(regFPR dst, regFPR src, immFPR con) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10414
  predicate(UseSSE==0 && !Compile::current()->select_24_bit_instr());
7433
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
 10415
  match(Set dst (MulF src con));
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
 10416
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
 10417
  format %{ "FLD    $src\n\t"
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
 10418
            "FMUL_S [$constantaddress]\t# load from constant table: float=$con\n\t"
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
 10419
            "FSTP   $dst"  %}
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
 10420
  ins_encode %{
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
 10421
    __ fld_s($src$$reg - 1);  // FLD ST(i-1)
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
 10422
    __ fmul_s($constantaddress($con));
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
 10423
    __ fstp_d($dst$$reg);
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
 10424
  %}
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
 10425
  ins_pipe(fpu_reg_reg_con);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10426
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10427
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10428
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10429
//
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10430
// MACRO1 -- subsume unshared load into mulFPR
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10431
// This instruction does not round to 24-bits
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10432
instruct mulFPR_reg_load1(regFPR dst, regFPR src, memory mem1 ) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10433
  predicate(UseSSE==0 && !Compile::current()->select_24_bit_instr());
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10434
  match(Set dst (MulF (LoadF mem1) src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10435
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10436
  format %{ "FLD    $mem1    ===MACRO1===\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10437
            "FMUL   ST,$src\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10438
            "FSTP   $dst" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10439
  opcode(0xD8, 0x1, 0xD9); /* D8 C8+i or D8 /1 */  /* LoadF D9 /0 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10440
  ins_encode( Opcode(tertiary), RMopc_Mem(0x00,mem1),
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10441
              OpcReg_FPR(src),
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10442
              Pop_Reg_FPR(dst) );
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10443
  ins_pipe( fpu_reg_reg_mem );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10444
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10445
//
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10446
// MACRO2 -- addFPR a mulFPR which subsumed an unshared load
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10447
// This instruction does not round to 24-bits
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10448
instruct addFPR_mulFPR_reg_load1(regFPR dst, memory mem1, regFPR src1, regFPR src2) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10449
  predicate(UseSSE==0 && !Compile::current()->select_24_bit_instr());
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10450
  match(Set dst (AddF (MulF (LoadF mem1) src1) src2));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10451
  ins_cost(95);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10452
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10453
  format %{ "FLD    $mem1     ===MACRO2===\n\t"
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10454
            "FMUL   ST,$src1  subsume mulFPR left load\n\t"
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10455
            "FADD   ST,$src2\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10456
            "FSTP   $dst" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10457
  opcode(0xD9); /* LoadF D9 /0 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10458
  ins_encode( OpcP, RMopc_Mem(0x00,mem1),
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10459
              FMul_ST_reg(src1),
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10460
              FAdd_ST_reg(src2),
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10461
              Pop_Reg_FPR(dst) );
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10462
  ins_pipe( fpu_reg_mem_reg_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10463
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10464
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10465
// MACRO3 -- addFPR a mulFPR
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10466
// This instruction does not round to 24-bits.  It is a '2-address'
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10467
// instruction in that the result goes back to src2.  This eliminates
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10468
// a move from the macro; possibly the register allocator will have
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10469
// to add it back (and maybe not).
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10470
instruct addFPR_mulFPR_reg(regFPR src2, regFPR src1, regFPR src0) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10471
  predicate(UseSSE==0 && !Compile::current()->select_24_bit_instr());
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10472
  match(Set src2 (AddF (MulF src0 src1) src2));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10473
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10474
  format %{ "FLD    $src0     ===MACRO3===\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10475
            "FMUL   ST,$src1\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10476
            "FADDP  $src2,ST" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10477
  opcode(0xD9); /* LoadF D9 /0 */
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10478
  ins_encode( Push_Reg_FPR(src0),
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10479
              FMul_ST_reg(src1),
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10480
              FAddP_reg_ST(src2) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10481
  ins_pipe( fpu_reg_reg_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10482
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10483
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10484
// MACRO4 -- divFPR subFPR
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10485
// This instruction does not round to 24-bits
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10486
instruct subFPR_divFPR_reg(regFPR dst, regFPR src1, regFPR src2, regFPR src3) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10487
  predicate(UseSSE==0 && !Compile::current()->select_24_bit_instr());
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10488
  match(Set dst (DivF (SubF src2 src1) src3));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10489
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10490
  format %{ "FLD    $src2   ===MACRO4===\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10491
            "FSUB   ST,$src1\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10492
            "FDIV   ST,$src3\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10493
            "FSTP  $dst" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10494
  opcode(0xDE, 0x7); /* DE F8+i or DE /7*/
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10495
  ins_encode( Push_Reg_FPR(src2),
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10496
              subFPR_divFPR_encode(src1,src3),
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10497
              Pop_Reg_FPR(dst) );
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10498
  ins_pipe( fpu_reg_reg_reg_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10499
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10500
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10501
// Spill to obtain 24-bit precision
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10502
instruct divFPR24_reg(stackSlotF dst, regFPR src1, regFPR src2) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10503
  predicate(UseSSE==0 && Compile::current()->select_24_bit_instr());
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10504
  match(Set dst (DivF src1 src2));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10505
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10506
  format %{ "FDIV   $dst,$src1,$src2" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10507
  opcode(0xD8, 0x6); /* D8 F0+i or DE /6*/
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10508
  ins_encode( Push_Reg_FPR(src1),
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10509
              OpcReg_FPR(src2),
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10510
              Pop_Mem_FPR(dst) );
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10511
  ins_pipe( fpu_mem_reg_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10512
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10513
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10514
// This instruction does not round to 24-bits
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10515
instruct divFPR_reg(regFPR dst, regFPR src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10516
  predicate(UseSSE==0 && !Compile::current()->select_24_bit_instr());
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10517
  match(Set dst (DivF dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10518
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10519
  format %{ "FDIV   $dst,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10520
  opcode(0xDE, 0x7); /* DE F8+i or DE /7*/
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10521
  ins_encode( Push_Reg_FPR(src),
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10522
              OpcP, RegOpc(dst) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10523
  ins_pipe( fpu_reg_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10524
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10525
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10526
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10527
// Spill to obtain 24-bit precision
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10528
instruct modFPR24_reg(stackSlotF dst, regFPR src1, regFPR src2, eAXRegI rax, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10529
  predicate( UseSSE==0 && Compile::current()->select_24_bit_instr());
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10530
  match(Set dst (ModF src1 src2));
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10531
  effect(KILL rax, KILL cr); // emitModDPR() uses EAX and EFLAGS
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10532
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10533
  format %{ "FMOD   $dst,$src1,$src2" %}
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10534
  ins_encode( Push_Reg_Mod_DPR(src1, src2),
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10535
              emitModDPR(),
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10536
              Push_Result_Mod_DPR(src2),
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10537
              Pop_Mem_FPR(dst));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10538
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10539
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10540
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10541
// This instruction does not round to 24-bits
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10542
instruct modFPR_reg(regFPR dst, regFPR src, eAXRegI rax, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10543
  predicate( UseSSE==0 && !Compile::current()->select_24_bit_instr());
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10544
  match(Set dst (ModF dst src));
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10545
  effect(KILL rax, KILL cr); // emitModDPR() uses EAX and EFLAGS
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10546
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10547
  format %{ "FMOD   $dst,$src" %}
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10548
  ins_encode(Push_Reg_Mod_DPR(dst, src),
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10549
              emitModDPR(),
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10550
              Push_Result_Mod_DPR(src),
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10551
              Pop_Reg_FPR(dst));
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10552
  ins_pipe( pipe_slow );
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10553
%}
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10554
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10555
instruct modF_reg(regF dst, regF src0, regF src1, eAXRegI rax, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10556
  predicate(UseSSE>=1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10557
  match(Set dst (ModF src0 src1));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10558
  effect(KILL rax, KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10559
  format %{ "SUB    ESP,4\t # FMOD\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10560
          "\tMOVSS  [ESP+0],$src1\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10561
          "\tFLD_S  [ESP+0]\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10562
          "\tMOVSS  [ESP+0],$src0\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10563
          "\tFLD_S  [ESP+0]\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10564
     "loop:\tFPREM\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10565
          "\tFWAIT\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10566
          "\tFNSTSW AX\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10567
          "\tSAHF\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10568
          "\tJP     loop\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10569
          "\tFSTP_S [ESP+0]\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10570
          "\tMOVSS  $dst,[ESP+0]\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10571
          "\tADD    ESP,4\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10572
          "\tFSTP   ST0\t # Restore FPU Stack"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10573
    %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10574
  ins_cost(250);
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10575
  ins_encode( Push_ModF_encoding(src0, src1), emitModDPR(), Push_ResultF(dst,0x4), PopFPU);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10576
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10577
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10578
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10579
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10580
//----------Arithmetic Conversion Instructions---------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10581
// The conversions operations are all Alpha sorted.  Please keep it that way!
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10582
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10583
instruct roundFloat_mem_reg(stackSlotF dst, regFPR src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10584
  predicate(UseSSE==0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10585
  match(Set dst (RoundFloat src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10586
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10587
  format %{ "FST_S  $dst,$src\t# F-round" %}
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10588
  ins_encode( Pop_Mem_Reg_FPR(dst, src) );
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10589
  ins_pipe( fpu_mem_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10590
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10591
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10592
instruct roundDouble_mem_reg(stackSlotD dst, regDPR src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10593
  predicate(UseSSE<=1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10594
  match(Set dst (RoundDouble src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10595
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10596
  format %{ "FST_D  $dst,$src\t# D-round" %}
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10597
  ins_encode( Pop_Mem_Reg_DPR(dst, src) );
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10598
  ins_pipe( fpu_mem_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10599
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10600
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10601
// Force rounding to 24-bit precision and 6-bit exponent
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10602
instruct convDPR2FPR_reg(stackSlotF dst, regDPR src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10603
  predicate(UseSSE==0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10604
  match(Set dst (ConvD2F src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10605
  format %{ "FST_S  $dst,$src\t# F-round" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10606
  expand %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10607
    roundFloat_mem_reg(dst,src);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10608
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10609
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10610
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10611
// Force rounding to 24-bit precision and 6-bit exponent
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10612
instruct convDPR2F_reg(regF dst, regDPR src, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10613
  predicate(UseSSE==1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10614
  match(Set dst (ConvD2F src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10615
  effect( KILL cr );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10616
  format %{ "SUB    ESP,4\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10617
            "FST_S  [ESP],$src\t# F-round\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10618
            "MOVSS  $dst,[ESP]\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10619
            "ADD ESP,4" %}
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10620
  ins_encode %{
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10621
    __ subptr(rsp, 4);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10622
    if ($src$$reg != FPR1L_enc) {
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10623
      __ fld_s($src$$reg-1);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10624
      __ fstp_s(Address(rsp, 0));
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10625
    } else {
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10626
      __ fst_s(Address(rsp, 0));
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10627
    }
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10628
    __ movflt($dst$$XMMRegister, Address(rsp, 0));
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10629
    __ addptr(rsp, 4);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10630
  %}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10631
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10632
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10633
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10634
// Force rounding double precision to single precision
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10635
instruct convD2F_reg(regF dst, regD src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10636
  predicate(UseSSE>=2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10637
  match(Set dst (ConvD2F src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10638
  format %{ "CVTSD2SS $dst,$src\t# F-round" %}
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10639
  ins_encode %{
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10640
    __ cvtsd2ss ($dst$$XMMRegister, $src$$XMMRegister);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10641
  %}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10642
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10643
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10644
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10645
instruct convFPR2DPR_reg_reg(regDPR dst, regFPR src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10646
  predicate(UseSSE==0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10647
  match(Set dst (ConvF2D src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10648
  format %{ "FST_S  $dst,$src\t# D-round" %}
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10649
  ins_encode( Pop_Reg_Reg_DPR(dst, src));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10650
  ins_pipe( fpu_reg_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10651
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10652
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10653
instruct convFPR2D_reg(stackSlotD dst, regFPR src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10654
  predicate(UseSSE==1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10655
  match(Set dst (ConvF2D src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10656
  format %{ "FST_D  $dst,$src\t# D-round" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10657
  expand %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10658
    roundDouble_mem_reg(dst,src);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10659
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10660
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10661
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10662
instruct convF2DPR_reg(regDPR dst, regF src, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10663
  predicate(UseSSE==1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10664
  match(Set dst (ConvF2D src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10665
  effect( KILL cr );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10666
  format %{ "SUB    ESP,4\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10667
            "MOVSS  [ESP] $src\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10668
            "FLD_S  [ESP]\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10669
            "ADD    ESP,4\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10670
            "FSTP   $dst\t# D-round" %}
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10671
  ins_encode %{
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10672
    __ subptr(rsp, 4);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10673
    __ movflt(Address(rsp, 0), $src$$XMMRegister);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10674
    __ fld_s(Address(rsp, 0));
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10675
    __ addptr(rsp, 4);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10676
    __ fstp_d($dst$$reg);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10677
  %}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10678
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10679
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10680
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10681
instruct convF2D_reg(regD dst, regF src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10682
  predicate(UseSSE>=2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10683
  match(Set dst (ConvF2D src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10684
  format %{ "CVTSS2SD $dst,$src\t# D-round" %}
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10685
  ins_encode %{
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10686
    __ cvtss2sd ($dst$$XMMRegister, $src$$XMMRegister);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10687
  %}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10688
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10689
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10690
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10691
// Convert a double to an int.  If the double is a NAN, stuff a zero in instead.
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10692
instruct convDPR2I_reg_reg( eAXRegI dst, eDXRegI tmp, regDPR src, eFlagsReg cr ) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10693
  predicate(UseSSE<=1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10694
  match(Set dst (ConvD2I src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10695
  effect( KILL tmp, KILL cr );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10696
  format %{ "FLD    $src\t# Convert double to int \n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10697
            "FLDCW  trunc mode\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10698
            "SUB    ESP,4\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10699
            "FISTp  [ESP + #0]\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10700
            "FLDCW  std/24-bit mode\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10701
            "POP    EAX\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10702
            "CMP    EAX,0x80000000\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10703
            "JNE,s  fast\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10704
            "FLD_D  $src\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10705
            "CALL   d2i_wrapper\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10706
      "fast:" %}
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10707
  ins_encode( Push_Reg_DPR(src), DPR2I_encoding(src) );
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10708
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10709
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10710
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10711
// Convert a double to an int.  If the double is a NAN, stuff a zero in instead.
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10712
instruct convD2I_reg_reg( eAXRegI dst, eDXRegI tmp, regD src, eFlagsReg cr ) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10713
  predicate(UseSSE>=2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10714
  match(Set dst (ConvD2I src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10715
  effect( KILL tmp, KILL cr );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10716
  format %{ "CVTTSD2SI $dst, $src\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10717
            "CMP    $dst,0x80000000\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10718
            "JNE,s  fast\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10719
            "SUB    ESP, 8\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10720
            "MOVSD  [ESP], $src\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10721
            "FLD_D  [ESP]\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10722
            "ADD    ESP, 8\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10723
            "CALL   d2i_wrapper\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10724
      "fast:" %}
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10725
  ins_encode %{
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10726
    Label fast;
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10727
    __ cvttsd2sil($dst$$Register, $src$$XMMRegister);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10728
    __ cmpl($dst$$Register, 0x80000000);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10729
    __ jccb(Assembler::notEqual, fast);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10730
    __ subptr(rsp, 8);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10731
    __ movdbl(Address(rsp, 0), $src$$XMMRegister);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10732
    __ fld_d(Address(rsp, 0));
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10733
    __ addptr(rsp, 8);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10734
    __ call(RuntimeAddress(CAST_FROM_FN_PTR(address, StubRoutines::d2i_wrapper())));
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10735
    __ bind(fast);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10736
  %}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10737
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10738
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10739
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10740
instruct convDPR2L_reg_reg( eADXRegL dst, regDPR src, eFlagsReg cr ) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10741
  predicate(UseSSE<=1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10742
  match(Set dst (ConvD2L src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10743
  effect( KILL cr );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10744
  format %{ "FLD    $src\t# Convert double to long\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10745
            "FLDCW  trunc mode\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10746
            "SUB    ESP,8\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10747
            "FISTp  [ESP + #0]\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10748
            "FLDCW  std/24-bit mode\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10749
            "POP    EAX\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10750
            "POP    EDX\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10751
            "CMP    EDX,0x80000000\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10752
            "JNE,s  fast\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10753
            "TEST   EAX,EAX\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10754
            "JNE,s  fast\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10755
            "FLD    $src\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10756
            "CALL   d2l_wrapper\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10757
      "fast:" %}
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10758
  ins_encode( Push_Reg_DPR(src),  DPR2L_encoding(src) );
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10759
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10760
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10761
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10762
// XMM lacks a float/double->long conversion, so use the old FPU stack.
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10763
instruct convD2L_reg_reg( eADXRegL dst, regD src, eFlagsReg cr ) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10764
  predicate (UseSSE>=2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10765
  match(Set dst (ConvD2L src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10766
  effect( KILL cr );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10767
  format %{ "SUB    ESP,8\t# Convert double to long\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10768
            "MOVSD  [ESP],$src\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10769
            "FLD_D  [ESP]\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10770
            "FLDCW  trunc mode\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10771
            "FISTp  [ESP + #0]\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10772
            "FLDCW  std/24-bit mode\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10773
            "POP    EAX\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10774
            "POP    EDX\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10775
            "CMP    EDX,0x80000000\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10776
            "JNE,s  fast\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10777
            "TEST   EAX,EAX\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10778
            "JNE,s  fast\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10779
            "SUB    ESP,8\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10780
            "MOVSD  [ESP],$src\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10781
            "FLD_D  [ESP]\n\t"
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10782
            "ADD    ESP,8\n\t"
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10783
            "CALL   d2l_wrapper\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10784
      "fast:" %}
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10785
  ins_encode %{
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10786
    Label fast;
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10787
    __ subptr(rsp, 8);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10788
    __ movdbl(Address(rsp, 0), $src$$XMMRegister);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10789
    __ fld_d(Address(rsp, 0));
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10790
    __ fldcw(ExternalAddress(StubRoutines::addr_fpu_cntrl_wrd_trunc()));
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10791
    __ fistp_d(Address(rsp, 0));
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10792
    // Restore the rounding mode, mask the exception
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10793
    if (Compile::current()->in_24_bit_fp_mode()) {
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10794
      __ fldcw(ExternalAddress(StubRoutines::addr_fpu_cntrl_wrd_24()));
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10795
    } else {
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10796
      __ fldcw(ExternalAddress(StubRoutines::addr_fpu_cntrl_wrd_std()));
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10797
    }
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10798
    // Load the converted long, adjust CPU stack
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10799
    __ pop(rax);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10800
    __ pop(rdx);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10801
    __ cmpl(rdx, 0x80000000);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10802
    __ jccb(Assembler::notEqual, fast);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10803
    __ testl(rax, rax);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10804
    __ jccb(Assembler::notEqual, fast);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10805
    __ subptr(rsp, 8);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10806
    __ movdbl(Address(rsp, 0), $src$$XMMRegister);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10807
    __ fld_d(Address(rsp, 0));
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10808
    __ addptr(rsp, 8);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10809
    __ call(RuntimeAddress(CAST_FROM_FN_PTR(address, StubRoutines::d2l_wrapper())));
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10810
    __ bind(fast);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10811
  %}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10812
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10813
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10814
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10815
// Convert a double to an int.  Java semantics require we do complex
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10816
// manglations in the corner cases.  So we set the rounding mode to
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10817
// 'zero', store the darned double down as an int, and reset the
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10818
// rounding mode to 'nearest'.  The hardware stores a flag value down
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10819
// if we would overflow or converted a NAN; we check for this and
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10820
// and go the slow path if needed.
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10821
instruct convFPR2I_reg_reg(eAXRegI dst, eDXRegI tmp, regFPR src, eFlagsReg cr ) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10822
  predicate(UseSSE==0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10823
  match(Set dst (ConvF2I src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10824
  effect( KILL tmp, KILL cr );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10825
  format %{ "FLD    $src\t# Convert float to int \n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10826
            "FLDCW  trunc mode\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10827
            "SUB    ESP,4\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10828
            "FISTp  [ESP + #0]\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10829
            "FLDCW  std/24-bit mode\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10830
            "POP    EAX\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10831
            "CMP    EAX,0x80000000\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10832
            "JNE,s  fast\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10833
            "FLD    $src\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10834
            "CALL   d2i_wrapper\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10835
      "fast:" %}
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10836
  // DPR2I_encoding works for FPR2I
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10837
  ins_encode( Push_Reg_FPR(src), DPR2I_encoding(src) );
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10838
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10839
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10840
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10841
// Convert a float in xmm to an int reg.
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10842
instruct convF2I_reg(eAXRegI dst, eDXRegI tmp, regF src, eFlagsReg cr ) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10843
  predicate(UseSSE>=1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10844
  match(Set dst (ConvF2I src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10845
  effect( KILL tmp, KILL cr );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10846
  format %{ "CVTTSS2SI $dst, $src\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10847
            "CMP    $dst,0x80000000\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10848
            "JNE,s  fast\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10849
            "SUB    ESP, 4\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10850
            "MOVSS  [ESP], $src\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10851
            "FLD    [ESP]\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10852
            "ADD    ESP, 4\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10853
            "CALL   d2i_wrapper\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10854
      "fast:" %}
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10855
  ins_encode %{
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10856
    Label fast;
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10857
    __ cvttss2sil($dst$$Register, $src$$XMMRegister);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10858
    __ cmpl($dst$$Register, 0x80000000);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10859
    __ jccb(Assembler::notEqual, fast);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10860
    __ subptr(rsp, 4);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10861
    __ movflt(Address(rsp, 0), $src$$XMMRegister);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10862
    __ fld_s(Address(rsp, 0));
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10863
    __ addptr(rsp, 4);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10864
    __ call(RuntimeAddress(CAST_FROM_FN_PTR(address, StubRoutines::d2i_wrapper())));
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10865
    __ bind(fast);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10866
  %}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10867
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10868
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10869
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10870
instruct convFPR2L_reg_reg( eADXRegL dst, regFPR src, eFlagsReg cr ) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10871
  predicate(UseSSE==0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10872
  match(Set dst (ConvF2L src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10873
  effect( KILL cr );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10874
  format %{ "FLD    $src\t# Convert float to long\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10875
            "FLDCW  trunc mode\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10876
            "SUB    ESP,8\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10877
            "FISTp  [ESP + #0]\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10878
            "FLDCW  std/24-bit mode\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10879
            "POP    EAX\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10880
            "POP    EDX\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10881
            "CMP    EDX,0x80000000\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10882
            "JNE,s  fast\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10883
            "TEST   EAX,EAX\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10884
            "JNE,s  fast\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10885
            "FLD    $src\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10886
            "CALL   d2l_wrapper\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10887
      "fast:" %}
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10888
  // DPR2L_encoding works for FPR2L
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10889
  ins_encode( Push_Reg_FPR(src), DPR2L_encoding(src) );
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10890
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10891
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10892
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10893
// XMM lacks a float/double->long conversion, so use the old FPU stack.
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10894
instruct convF2L_reg_reg( eADXRegL dst, regF src, eFlagsReg cr ) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10895
  predicate (UseSSE>=1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10896
  match(Set dst (ConvF2L src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10897
  effect( KILL cr );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10898
  format %{ "SUB    ESP,8\t# Convert float to long\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10899
            "MOVSS  [ESP],$src\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10900
            "FLD_S  [ESP]\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10901
            "FLDCW  trunc mode\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10902
            "FISTp  [ESP + #0]\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10903
            "FLDCW  std/24-bit mode\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10904
            "POP    EAX\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10905
            "POP    EDX\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10906
            "CMP    EDX,0x80000000\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10907
            "JNE,s  fast\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10908
            "TEST   EAX,EAX\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10909
            "JNE,s  fast\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10910
            "SUB    ESP,4\t# Convert float to long\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10911
            "MOVSS  [ESP],$src\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10912
            "FLD_S  [ESP]\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10913
            "ADD    ESP,4\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10914
            "CALL   d2l_wrapper\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10915
      "fast:" %}
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10916
  ins_encode %{
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10917
    Label fast;
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10918
    __ subptr(rsp, 8);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10919
    __ movflt(Address(rsp, 0), $src$$XMMRegister);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10920
    __ fld_s(Address(rsp, 0));
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10921
    __ fldcw(ExternalAddress(StubRoutines::addr_fpu_cntrl_wrd_trunc()));
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10922
    __ fistp_d(Address(rsp, 0));
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10923
    // Restore the rounding mode, mask the exception
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10924
    if (Compile::current()->in_24_bit_fp_mode()) {
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10925
      __ fldcw(ExternalAddress(StubRoutines::addr_fpu_cntrl_wrd_24()));
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10926
    } else {
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10927
      __ fldcw(ExternalAddress(StubRoutines::addr_fpu_cntrl_wrd_std()));
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10928
    }
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10929
    // Load the converted long, adjust CPU stack
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10930
    __ pop(rax);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10931
    __ pop(rdx);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10932
    __ cmpl(rdx, 0x80000000);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10933
    __ jccb(Assembler::notEqual, fast);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10934
    __ testl(rax, rax);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10935
    __ jccb(Assembler::notEqual, fast);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10936
    __ subptr(rsp, 4);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10937
    __ movflt(Address(rsp, 0), $src$$XMMRegister);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10938
    __ fld_s(Address(rsp, 0));
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10939
    __ addptr(rsp, 4);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10940
    __ call(RuntimeAddress(CAST_FROM_FN_PTR(address, StubRoutines::d2l_wrapper())));
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10941
    __ bind(fast);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10942
  %}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10943
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10944
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10945
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10946
instruct convI2DPR_reg(regDPR dst, stackSlotI src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10947
  predicate( UseSSE<=1 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10948
  match(Set dst (ConvI2D src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10949
  format %{ "FILD   $src\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10950
            "FSTP   $dst" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10951
  opcode(0xDB, 0x0);  /* DB /0 */
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10952
  ins_encode(Push_Mem_I(src), Pop_Reg_DPR(dst));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10953
  ins_pipe( fpu_reg_mem );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10954
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10955
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
 10956
instruct convI2D_reg(regD dst, rRegI src) %{
244
c8ad6f221400 6662967: Optimize I2D conversion on new x86
kvn
parents: 1
diff changeset
 10957
  predicate( UseSSE>=2 && !UseXmmI2D );
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10958
  match(Set dst (ConvI2D src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10959
  format %{ "CVTSI2SD $dst,$src" %}
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10960
  ins_encode %{
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10961
    __ cvtsi2sdl ($dst$$XMMRegister, $src$$Register);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10962
  %}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10963
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10964
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10965
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10966
instruct convI2D_mem(regD dst, memory mem) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10967
  predicate( UseSSE>=2 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10968
  match(Set dst (ConvI2D (LoadI mem)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10969
  format %{ "CVTSI2SD $dst,$mem" %}
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10970
  ins_encode %{
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10971
    __ cvtsi2sdl ($dst$$XMMRegister, $mem$$Address);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 10972
  %}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10973
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10974
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10975
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
 10976
instruct convXI2D_reg(regD dst, rRegI src)
244
c8ad6f221400 6662967: Optimize I2D conversion on new x86
kvn
parents: 1
diff changeset
 10977
%{
c8ad6f221400 6662967: Optimize I2D conversion on new x86
kvn
parents: 1
diff changeset
 10978
  predicate( UseSSE>=2 && UseXmmI2D );
c8ad6f221400 6662967: Optimize I2D conversion on new x86
kvn
parents: 1
diff changeset
 10979
  match(Set dst (ConvI2D src));
c8ad6f221400 6662967: Optimize I2D conversion on new x86
kvn
parents: 1
diff changeset
 10980
c8ad6f221400 6662967: Optimize I2D conversion on new x86
kvn
parents: 1
diff changeset
 10981
  format %{ "MOVD  $dst,$src\n\t"
c8ad6f221400 6662967: Optimize I2D conversion on new x86
kvn
parents: 1
diff changeset
 10982
            "CVTDQ2PD $dst,$dst\t# i2d" %}
c8ad6f221400 6662967: Optimize I2D conversion on new x86
kvn
parents: 1
diff changeset
 10983
  ins_encode %{
1066
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
 10984
    __ movdl($dst$$XMMRegister, $src$$Register);
244
c8ad6f221400 6662967: Optimize I2D conversion on new x86
kvn
parents: 1
diff changeset
 10985
    __ cvtdq2pd($dst$$XMMRegister, $dst$$XMMRegister);
c8ad6f221400 6662967: Optimize I2D conversion on new x86
kvn
parents: 1
diff changeset
 10986
  %}
c8ad6f221400 6662967: Optimize I2D conversion on new x86
kvn
parents: 1
diff changeset
 10987
  ins_pipe(pipe_slow); // XXX
c8ad6f221400 6662967: Optimize I2D conversion on new x86
kvn
parents: 1
diff changeset
 10988
%}
c8ad6f221400 6662967: Optimize I2D conversion on new x86
kvn
parents: 1
diff changeset
 10989
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10990
instruct convI2DPR_mem(regDPR dst, memory mem) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10991
  predicate( UseSSE<=1 && !Compile::current()->select_24_bit_instr());
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10992
  match(Set dst (ConvI2D (LoadI mem)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10993
  format %{ "FILD   $mem\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10994
            "FSTP   $dst" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10995
  opcode(0xDB);      /* DB /0 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10996
  ins_encode( OpcP, RMopc_Mem(0x00,mem),
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 10997
              Pop_Reg_DPR(dst));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10998
  ins_pipe( fpu_reg_mem );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10999
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11000
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11001
// Convert a byte to a float; no rounding step needed.
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 11002
instruct conv24I2FPR_reg(regFPR dst, stackSlotI src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11003
  predicate( UseSSE==0 && n->in(1)->Opcode() == Op_AndI && n->in(1)->in(2)->is_Con() && n->in(1)->in(2)->get_int() == 255 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11004
  match(Set dst (ConvI2F src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11005
  format %{ "FILD   $src\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11006
            "FSTP   $dst" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11007
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11008
  opcode(0xDB, 0x0);  /* DB /0 */
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 11009
  ins_encode(Push_Mem_I(src), Pop_Reg_FPR(dst));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11010
  ins_pipe( fpu_reg_mem );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11011
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11012
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11013
// In 24-bit mode, force exponent rounding by storing back out
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 11014
instruct convI2FPR_SSF(stackSlotF dst, stackSlotI src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11015
  predicate( UseSSE==0 && Compile::current()->select_24_bit_instr());
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11016
  match(Set dst (ConvI2F src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11017
  ins_cost(200);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11018
  format %{ "FILD   $src\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11019
            "FSTP_S $dst" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11020
  opcode(0xDB, 0x0);  /* DB /0 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11021
  ins_encode( Push_Mem_I(src),
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 11022
              Pop_Mem_FPR(dst));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11023
  ins_pipe( fpu_mem_mem );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11024
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11025
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11026
// In 24-bit mode, force exponent rounding by storing back out
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 11027
instruct convI2FPR_SSF_mem(stackSlotF dst, memory mem) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11028
  predicate( UseSSE==0 && Compile::current()->select_24_bit_instr());
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11029
  match(Set dst (ConvI2F (LoadI mem)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11030
  ins_cost(200);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11031
  format %{ "FILD   $mem\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11032
            "FSTP_S $dst" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11033
  opcode(0xDB);  /* DB /0 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11034
  ins_encode( OpcP, RMopc_Mem(0x00,mem),
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 11035
              Pop_Mem_FPR(dst));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11036
  ins_pipe( fpu_mem_mem );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11037
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11038
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11039
// This instruction does not round to 24-bits
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 11040
instruct convI2FPR_reg(regFPR dst, stackSlotI src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11041
  predicate( UseSSE==0 && !Compile::current()->select_24_bit_instr());
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11042
  match(Set dst (ConvI2F src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11043
  format %{ "FILD   $src\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11044
            "FSTP   $dst" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11045
  opcode(0xDB, 0x0);  /* DB /0 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11046
  ins_encode( Push_Mem_I(src),
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 11047
              Pop_Reg_FPR(dst));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11048
  ins_pipe( fpu_reg_mem );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11049
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11050
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11051
// This instruction does not round to 24-bits
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 11052
instruct convI2FPR_mem(regFPR dst, memory mem) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11053
  predicate( UseSSE==0 && !Compile::current()->select_24_bit_instr());
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11054
  match(Set dst (ConvI2F (LoadI mem)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11055
  format %{ "FILD   $mem\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11056
            "FSTP   $dst" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11057
  opcode(0xDB);      /* DB /0 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11058
  ins_encode( OpcP, RMopc_Mem(0x00,mem),
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 11059
              Pop_Reg_FPR(dst));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11060
  ins_pipe( fpu_reg_mem );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11061
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11062
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11063
// Convert an int to a float in xmm; no rounding step needed.
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
 11064
instruct convI2F_reg(regF dst, rRegI src) %{
244
c8ad6f221400 6662967: Optimize I2D conversion on new x86
kvn
parents: 1
diff changeset
 11065
  predicate( UseSSE==1 || UseSSE>=2 && !UseXmmI2F );
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11066
  match(Set dst (ConvI2F src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11067
  format %{ "CVTSI2SS $dst, $src" %}
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 11068
  ins_encode %{
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 11069
    __ cvtsi2ssl ($dst$$XMMRegister, $src$$Register);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 11070
  %}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11071
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11072
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11073
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
 11074
 instruct convXI2F_reg(regF dst, rRegI src)
244
c8ad6f221400 6662967: Optimize I2D conversion on new x86
kvn
parents: 1
diff changeset
 11075
%{
c8ad6f221400 6662967: Optimize I2D conversion on new x86
kvn
parents: 1
diff changeset
 11076
  predicate( UseSSE>=2 && UseXmmI2F );
c8ad6f221400 6662967: Optimize I2D conversion on new x86
kvn
parents: 1
diff changeset
 11077
  match(Set dst (ConvI2F src));
c8ad6f221400 6662967: Optimize I2D conversion on new x86
kvn
parents: 1
diff changeset
 11078
c8ad6f221400 6662967: Optimize I2D conversion on new x86
kvn
parents: 1
diff changeset
 11079
  format %{ "MOVD  $dst,$src\n\t"
c8ad6f221400 6662967: Optimize I2D conversion on new x86
kvn
parents: 1
diff changeset
 11080
            "CVTDQ2PS $dst,$dst\t# i2f" %}
c8ad6f221400 6662967: Optimize I2D conversion on new x86
kvn
parents: 1
diff changeset
 11081
  ins_encode %{
1066
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
 11082
    __ movdl($dst$$XMMRegister, $src$$Register);
244
c8ad6f221400 6662967: Optimize I2D conversion on new x86
kvn
parents: 1
diff changeset
 11083
    __ cvtdq2ps($dst$$XMMRegister, $dst$$XMMRegister);
c8ad6f221400 6662967: Optimize I2D conversion on new x86
kvn
parents: 1
diff changeset
 11084
  %}
c8ad6f221400 6662967: Optimize I2D conversion on new x86
kvn
parents: 1
diff changeset
 11085
  ins_pipe(pipe_slow); // XXX
c8ad6f221400 6662967: Optimize I2D conversion on new x86
kvn
parents: 1
diff changeset
 11086
%}
c8ad6f221400 6662967: Optimize I2D conversion on new x86
kvn
parents: 1
diff changeset
 11087
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
 11088
instruct convI2L_reg( eRegL dst, rRegI src, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11089
  match(Set dst (ConvI2L src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11090
  effect(KILL cr);
2150
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
 11091
  ins_cost(375);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11092
  format %{ "MOV    $dst.lo,$src\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11093
            "MOV    $dst.hi,$src\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11094
            "SAR    $dst.hi,31" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11095
  ins_encode(convert_int_long(dst,src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11096
  ins_pipe( ialu_reg_reg_long );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11097
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11098
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11099
// Zero-extend convert int to long
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
 11100
instruct convI2L_reg_zex(eRegL dst, rRegI src, immL_32bits mask, eFlagsReg flags ) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11101
  match(Set dst (AndL (ConvI2L src) mask) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11102
  effect( KILL flags );
2150
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
 11103
  ins_cost(250);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11104
  format %{ "MOV    $dst.lo,$src\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11105
            "XOR    $dst.hi,$dst.hi" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11106
  opcode(0x33); // XOR
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11107
  ins_encode(enc_Copy(dst,src), OpcP, RegReg_Hi2(dst,dst) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11108
  ins_pipe( ialu_reg_reg_long );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11109
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11110
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11111
// Zero-extend long
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11112
instruct zerox_long(eRegL dst, eRegL src, immL_32bits mask, eFlagsReg flags ) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11113
  match(Set dst (AndL src mask) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11114
  effect( KILL flags );
2150
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
 11115
  ins_cost(250);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11116
  format %{ "MOV    $dst.lo,$src.lo\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11117
            "XOR    $dst.hi,$dst.hi\n\t" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11118
  opcode(0x33); // XOR
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11119
  ins_encode(enc_Copy(dst,src), OpcP, RegReg_Hi2(dst,dst) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11120
  ins_pipe( ialu_reg_reg_long );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11121
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11122
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 11123
instruct convL2DPR_reg( stackSlotD dst, eRegL src, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11124
  predicate (UseSSE<=1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11125
  match(Set dst (ConvL2D src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11126
  effect( KILL cr );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11127
  format %{ "PUSH   $src.hi\t# Convert long to double\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11128
            "PUSH   $src.lo\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11129
            "FILD   ST,[ESP + #0]\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11130
            "ADD    ESP,8\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11131
            "FSTP_D $dst\t# D-round" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11132
  opcode(0xDF, 0x5);  /* DF /5 */
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 11133
  ins_encode(convert_long_double(src), Pop_Mem_DPR(dst));
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 11134
  ins_pipe( pipe_slow );
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 11135
%}
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 11136
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 11137
instruct convL2D_reg( regD dst, eRegL src, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11138
  predicate (UseSSE>=2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11139
  match(Set dst (ConvL2D src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11140
  effect( KILL cr );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11141
  format %{ "PUSH   $src.hi\t# Convert long to double\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11142
            "PUSH   $src.lo\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11143
            "FILD_D [ESP]\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11144
            "FSTP_D [ESP]\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11145
            "MOVSD  $dst,[ESP]\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11146
            "ADD    ESP,8" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11147
  opcode(0xDF, 0x5);  /* DF /5 */
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 11148
  ins_encode(convert_long_double2(src), Push_ResultD(dst));
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 11149
  ins_pipe( pipe_slow );
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 11150
%}
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 11151
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 11152
instruct convL2F_reg( regF dst, eRegL src, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11153
  predicate (UseSSE>=1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11154
  match(Set dst (ConvL2F src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11155
  effect( KILL cr );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11156
  format %{ "PUSH   $src.hi\t# Convert long to single float\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11157
            "PUSH   $src.lo\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11158
            "FILD_D [ESP]\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11159
            "FSTP_S [ESP]\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11160
            "MOVSS  $dst,[ESP]\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11161
            "ADD    ESP,8" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11162
  opcode(0xDF, 0x5);  /* DF /5 */
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 11163
  ins_encode(convert_long_double2(src), Push_ResultF(dst,0x8));
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 11164
  ins_pipe( pipe_slow );
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 11165
%}
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 11166
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 11167
instruct convL2FPR_reg( stackSlotF dst, eRegL src, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11168
  match(Set dst (ConvL2F src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11169
  effect( KILL cr );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11170
  format %{ "PUSH   $src.hi\t# Convert long to single float\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11171
            "PUSH   $src.lo\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11172
            "FILD   ST,[ESP + #0]\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11173
            "ADD    ESP,8\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11174
            "FSTP_S $dst\t# F-round" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11175
  opcode(0xDF, 0x5);  /* DF /5 */
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 11176
  ins_encode(convert_long_double(src), Pop_Mem_FPR(dst));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11177
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11178
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11179
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
 11180
instruct convL2I_reg( rRegI dst, eRegL src ) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11181
  match(Set dst (ConvL2I src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11182
  effect( DEF dst, USE src );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11183
  format %{ "MOV    $dst,$src.lo" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11184
  ins_encode(enc_CopyL_Lo(dst,src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11185
  ins_pipe( ialu_reg_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11186
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11187
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
 11188
instruct MoveF2I_stack_reg(rRegI dst, stackSlotF src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11189
  match(Set dst (MoveF2I src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11190
  effect( DEF dst, USE src );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11191
  ins_cost(100);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11192
  format %{ "MOV    $dst,$src\t# MoveF2I_stack_reg" %}
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 11193
  ins_encode %{
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 11194
    __ movl($dst$$Register, Address(rsp, $src$$disp));
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 11195
  %}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11196
  ins_pipe( ialu_reg_mem );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11197
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11198
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 11199
instruct MoveFPR2I_reg_stack(stackSlotI dst, regFPR src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11200
  predicate(UseSSE==0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11201
  match(Set dst (MoveF2I src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11202
  effect( DEF dst, USE src );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11203
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11204
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11205
  format %{ "FST_S  $dst,$src\t# MoveF2I_reg_stack" %}
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 11206
  ins_encode( Pop_Mem_Reg_FPR(dst, src) );
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11207
  ins_pipe( fpu_mem_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11208
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11209
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 11210
instruct MoveF2I_reg_stack_sse(stackSlotI dst, regF src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11211
  predicate(UseSSE>=1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11212
  match(Set dst (MoveF2I src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11213
  effect( DEF dst, USE src );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11214
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11215
  ins_cost(95);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11216
  format %{ "MOVSS  $dst,$src\t# MoveF2I_reg_stack_sse" %}
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 11217
  ins_encode %{
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 11218
    __ movflt(Address(rsp, $dst$$disp), $src$$XMMRegister);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 11219
  %}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11220
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11221
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11222
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
 11223
instruct MoveF2I_reg_reg_sse(rRegI dst, regF src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11224
  predicate(UseSSE>=2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11225
  match(Set dst (MoveF2I src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11226
  effect( DEF dst, USE src );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11227
  ins_cost(85);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11228
  format %{ "MOVD   $dst,$src\t# MoveF2I_reg_reg_sse" %}
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 11229
  ins_encode %{
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 11230
    __ movdl($dst$$Register, $src$$XMMRegister);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 11231
  %}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11232
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11233
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11234
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
 11235
instruct MoveI2F_reg_stack(stackSlotF dst, rRegI src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11236
  match(Set dst (MoveI2F src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11237
  effect( DEF dst, USE src );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11238
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11239
  ins_cost(100);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11240
  format %{ "MOV    $dst,$src\t# MoveI2F_reg_stack" %}
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 11241
  ins_encode %{
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 11242
    __ movl(Address(rsp, $dst$$disp), $src$$Register);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 11243
  %}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11244
  ins_pipe( ialu_mem_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11245
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11246
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11247
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 11248
instruct MoveI2FPR_stack_reg(regFPR dst, stackSlotI src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11249
  predicate(UseSSE==0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11250
  match(Set dst (MoveI2F src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11251
  effect(DEF dst, USE src);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11252
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11253
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11254
  format %{ "FLD_S  $src\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11255
            "FSTP   $dst\t# MoveI2F_stack_reg" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11256
  opcode(0xD9);               /* D9 /0, FLD m32real */
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11257
  ins_encode( OpcP, RMopc_Mem_no_oop(0x00,src),
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 11258
              Pop_Reg_FPR(dst) );
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11259
  ins_pipe( fpu_reg_mem );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11260
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11261
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 11262
instruct MoveI2F_stack_reg_sse(regF dst, stackSlotI src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11263
  predicate(UseSSE>=1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11264
  match(Set dst (MoveI2F src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11265
  effect( DEF dst, USE src );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11266
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11267
  ins_cost(95);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11268
  format %{ "MOVSS  $dst,$src\t# MoveI2F_stack_reg_sse" %}
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 11269
  ins_encode %{
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 11270
    __ movflt($dst$$XMMRegister, Address(rsp, $src$$disp));
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 11271
  %}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11272
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11273
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11274
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
 11275
instruct MoveI2F_reg_reg_sse(regF dst, rRegI src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11276
  predicate(UseSSE>=2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11277
  match(Set dst (MoveI2F src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11278
  effect( DEF dst, USE src );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11279
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11280
  ins_cost(85);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11281
  format %{ "MOVD   $dst,$src\t# MoveI2F_reg_reg_sse" %}
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 11282
  ins_encode %{
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 11283
    __ movdl($dst$$XMMRegister, $src$$Register);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 11284
  %}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11285
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11286
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11287
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11288
instruct MoveD2L_stack_reg(eRegL dst, stackSlotD src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11289
  match(Set dst (MoveD2L src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11290
  effect(DEF dst, USE src);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11291
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11292
  ins_cost(250);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11293
  format %{ "MOV    $dst.lo,$src\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11294
            "MOV    $dst.hi,$src+4\t# MoveD2L_stack_reg" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11295
  opcode(0x8B, 0x8B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11296
  ins_encode( OpcP, RegMem(dst,src), OpcS, RegMem_Hi(dst,src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11297
  ins_pipe( ialu_mem_long_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11298
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11299
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 11300
instruct MoveDPR2L_reg_stack(stackSlotL dst, regDPR src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11301
  predicate(UseSSE<=1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11302
  match(Set dst (MoveD2L src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11303
  effect(DEF dst, USE src);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11304
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11305
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11306
  format %{ "FST_D  $dst,$src\t# MoveD2L_reg_stack" %}
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 11307
  ins_encode( Pop_Mem_Reg_DPR(dst, src) );
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11308
  ins_pipe( fpu_mem_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11309
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11310
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 11311
instruct MoveD2L_reg_stack_sse(stackSlotL dst, regD src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11312
  predicate(UseSSE>=2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11313
  match(Set dst (MoveD2L src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11314
  effect(DEF dst, USE src);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11315
  ins_cost(95);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11316
  format %{ "MOVSD  $dst,$src\t# MoveD2L_reg_stack_sse" %}
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 11317
  ins_encode %{
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 11318
    __ movdbl(Address(rsp, $dst$$disp), $src$$XMMRegister);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 11319
  %}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11320
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11321
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11322
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 11323
instruct MoveD2L_reg_reg_sse(eRegL dst, regD src, regD tmp) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11324
  predicate(UseSSE>=2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11325
  match(Set dst (MoveD2L src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11326
  effect(DEF dst, USE src, TEMP tmp);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11327
  ins_cost(85);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11328
  format %{ "MOVD   $dst.lo,$src\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11329
            "PSHUFLW $tmp,$src,0x4E\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11330
            "MOVD   $dst.hi,$tmp\t# MoveD2L_reg_reg_sse" %}
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 11331
  ins_encode %{
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 11332
    __ movdl($dst$$Register, $src$$XMMRegister);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 11333
    __ pshuflw($tmp$$XMMRegister, $src$$XMMRegister, 0x4e);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 11334
    __ movdl(HIGH_FROM_LOW($dst$$Register), $tmp$$XMMRegister);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 11335
  %}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11336
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11337
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11338
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11339
instruct MoveL2D_reg_stack(stackSlotD dst, eRegL src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11340
  match(Set dst (MoveL2D src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11341
  effect(DEF dst, USE src);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11342
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11343
  ins_cost(200);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11344
  format %{ "MOV    $dst,$src.lo\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11345
            "MOV    $dst+4,$src.hi\t# MoveL2D_reg_stack" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11346
  opcode(0x89, 0x89);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11347
  ins_encode( OpcP, RegMem( src, dst ), OpcS, RegMem_Hi( src, dst ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11348
  ins_pipe( ialu_mem_long_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11349
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11350
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11351
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 11352
instruct MoveL2DPR_stack_reg(regDPR dst, stackSlotL src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11353
  predicate(UseSSE<=1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11354
  match(Set dst (MoveL2D src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11355
  effect(DEF dst, USE src);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11356
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11357
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11358
  format %{ "FLD_D  $src\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11359
            "FSTP   $dst\t# MoveL2D_stack_reg" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11360
  opcode(0xDD);               /* DD /0, FLD m64real */
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11361
  ins_encode( OpcP, RMopc_Mem_no_oop(0x00,src),
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 11362
              Pop_Reg_DPR(dst) );
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11363
  ins_pipe( fpu_reg_mem );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11364
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11365
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11366
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 11367
instruct MoveL2D_stack_reg_sse(regD dst, stackSlotL src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11368
  predicate(UseSSE>=2 && UseXmmLoadAndClearUpper);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11369
  match(Set dst (MoveL2D src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11370
  effect(DEF dst, USE src);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11371
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11372
  ins_cost(95);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11373
  format %{ "MOVSD  $dst,$src\t# MoveL2D_stack_reg_sse" %}
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 11374
  ins_encode %{
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 11375
    __ movdbl($dst$$XMMRegister, Address(rsp, $src$$disp));
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 11376
  %}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11377
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11378
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11379
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 11380
instruct MoveL2D_stack_reg_sse_partial(regD dst, stackSlotL src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11381
  predicate(UseSSE>=2 && !UseXmmLoadAndClearUpper);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11382
  match(Set dst (MoveL2D src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11383
  effect(DEF dst, USE src);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11384
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11385
  ins_cost(95);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11386
  format %{ "MOVLPD $dst,$src\t# MoveL2D_stack_reg_sse" %}
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 11387
  ins_encode %{
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 11388
    __ movdbl($dst$$XMMRegister, Address(rsp, $src$$disp));
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 11389
  %}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11390
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11391
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11392
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 11393
instruct MoveL2D_reg_reg_sse(regD dst, eRegL src, regD tmp) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11394
  predicate(UseSSE>=2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11395
  match(Set dst (MoveL2D src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11396
  effect(TEMP dst, USE src, TEMP tmp);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11397
  ins_cost(85);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11398
  format %{ "MOVD   $dst,$src.lo\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11399
            "MOVD   $tmp,$src.hi\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11400
            "PUNPCKLDQ $dst,$tmp\t# MoveL2D_reg_reg_sse" %}
11427
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 11401
  ins_encode %{
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 11402
    __ movdl($dst$$XMMRegister, $src$$Register);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 11403
    __ movdl($tmp$$XMMRegister, HIGH_FROM_LOW($src$$Register));
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 11404
    __ punpckldq($dst$$XMMRegister, $tmp$$XMMRegister);
bf248009cbbe 7116452: Add support for AVX instructions
kvn
parents: 11197
diff changeset
 11405
  %}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11406
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11407
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11408
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11409
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11410
// =======================================================================
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11411
// fast clearing of an array
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11412
instruct rep_stos(eCXRegI cnt, eDIRegP base, eAXRegI zero, Universe dummy, eFlagsReg cr) %{
15114
4074553c678b 8005522: use fast-string instructions on x86 for zeroing
kvn
parents: 13974
diff changeset
 11413
  predicate(!UseFastStosb);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11414
  match(Set dummy (ClearArray cnt base));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11415
  effect(USE_KILL cnt, USE_KILL base, KILL zero, KILL cr);
15114
4074553c678b 8005522: use fast-string instructions on x86 for zeroing
kvn
parents: 13974
diff changeset
 11416
  format %{ "XOR    EAX,EAX\t# ClearArray:\n\t"
4074553c678b 8005522: use fast-string instructions on x86 for zeroing
kvn
parents: 13974
diff changeset
 11417
            "SHL    ECX,1\t# Convert doublewords to words\n\t"
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11418
            "REP STOS\t# store EAX into [EDI++] while ECX--" %}
30624
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
 11419
  ins_encode %{
15114
4074553c678b 8005522: use fast-string instructions on x86 for zeroing
kvn
parents: 13974
diff changeset
 11420
    __ clear_mem($base$$Register, $cnt$$Register, $zero$$Register);
4074553c678b 8005522: use fast-string instructions on x86 for zeroing
kvn
parents: 13974
diff changeset
 11421
  %}
4074553c678b 8005522: use fast-string instructions on x86 for zeroing
kvn
parents: 13974
diff changeset
 11422
  ins_pipe( pipe_slow );
4074553c678b 8005522: use fast-string instructions on x86 for zeroing
kvn
parents: 13974
diff changeset
 11423
%}
4074553c678b 8005522: use fast-string instructions on x86 for zeroing
kvn
parents: 13974
diff changeset
 11424
4074553c678b 8005522: use fast-string instructions on x86 for zeroing
kvn
parents: 13974
diff changeset
 11425
instruct rep_fast_stosb(eCXRegI cnt, eDIRegP base, eAXRegI zero, Universe dummy, eFlagsReg cr) %{
4074553c678b 8005522: use fast-string instructions on x86 for zeroing
kvn
parents: 13974
diff changeset
 11426
  predicate(UseFastStosb);
4074553c678b 8005522: use fast-string instructions on x86 for zeroing
kvn
parents: 13974
diff changeset
 11427
  match(Set dummy (ClearArray cnt base));
4074553c678b 8005522: use fast-string instructions on x86 for zeroing
kvn
parents: 13974
diff changeset
 11428
  effect(USE_KILL cnt, USE_KILL base, KILL zero, KILL cr);
4074553c678b 8005522: use fast-string instructions on x86 for zeroing
kvn
parents: 13974
diff changeset
 11429
  format %{ "XOR    EAX,EAX\t# ClearArray:\n\t"
4074553c678b 8005522: use fast-string instructions on x86 for zeroing
kvn
parents: 13974
diff changeset
 11430
            "SHL    ECX,3\t# Convert doublewords to bytes\n\t"
4074553c678b 8005522: use fast-string instructions on x86 for zeroing
kvn
parents: 13974
diff changeset
 11431
            "REP STOSB\t# store EAX into [EDI++] while ECX--" %}
30624
2e1803c8a26d 8076276: Add support for AVX512
kvn
parents: 30305
diff changeset
 11432
  ins_encode %{
15114
4074553c678b 8005522: use fast-string instructions on x86 for zeroing
kvn
parents: 13974
diff changeset
 11433
    __ clear_mem($base$$Register, $cnt$$Register, $zero$$Register);
4074553c678b 8005522: use fast-string instructions on x86 for zeroing
kvn
parents: 13974
diff changeset
 11434
  %}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11435
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11436
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11437
33628
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11438
instruct string_compareL(eDIRegP str1, eCXRegI cnt1, eSIRegP str2, eDXRegI cnt2,
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11439
                         eAXRegI result, regD tmp1, eFlagsReg cr) %{
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11440
  predicate(((StrCompNode*)n)->encoding() == StrIntrinsicNode::LL);
3905
7d725029ac85 6827605: new String intrinsics may prevent EA scalar replacement
kvn
parents: 3177
diff changeset
 11441
  match(Set result (StrComp (Binary str1 cnt1) (Binary str2 cnt2)));
8332
3320859e937a 7016474: string compare intrinsic improvements
never
parents: 7433
diff changeset
 11442
  effect(TEMP tmp1, USE_KILL str1, USE_KILL str2, USE_KILL cnt1, USE_KILL cnt2, KILL cr);
3320859e937a 7016474: string compare intrinsic improvements
never
parents: 7433
diff changeset
 11443
33628
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11444
  format %{ "String Compare byte[] $str1,$cnt1,$str2,$cnt2 -> $result   // KILL $tmp1" %}
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11445
  ins_encode %{
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11446
    __ string_compare($str1$$Register, $str2$$Register,
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11447
                      $cnt1$$Register, $cnt2$$Register, $result$$Register,
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11448
                      $tmp1$$XMMRegister, StrIntrinsicNode::LL);
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11449
  %}
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11450
  ins_pipe( pipe_slow );
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11451
%}
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11452
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11453
instruct string_compareU(eDIRegP str1, eCXRegI cnt1, eSIRegP str2, eDXRegI cnt2,
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11454
                         eAXRegI result, regD tmp1, eFlagsReg cr) %{
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11455
  predicate(((StrCompNode*)n)->encoding() == StrIntrinsicNode::UU);
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11456
  match(Set result (StrComp (Binary str1 cnt1) (Binary str2 cnt2)));
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11457
  effect(TEMP tmp1, USE_KILL str1, USE_KILL str2, USE_KILL cnt1, USE_KILL cnt2, KILL cr);
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11458
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11459
  format %{ "String Compare char[] $str1,$cnt1,$str2,$cnt2 -> $result   // KILL $tmp1" %}
3905
7d725029ac85 6827605: new String intrinsics may prevent EA scalar replacement
kvn
parents: 3177
diff changeset
 11460
  ins_encode %{
7d725029ac85 6827605: new String intrinsics may prevent EA scalar replacement
kvn
parents: 3177
diff changeset
 11461
    __ string_compare($str1$$Register, $str2$$Register,
7d725029ac85 6827605: new String intrinsics may prevent EA scalar replacement
kvn
parents: 3177
diff changeset
 11462
                      $cnt1$$Register, $cnt2$$Register, $result$$Register,
33628
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11463
                      $tmp1$$XMMRegister, StrIntrinsicNode::UU);
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11464
  %}
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11465
  ins_pipe( pipe_slow );
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11466
%}
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11467
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11468
instruct string_compareLU(eDIRegP str1, eCXRegI cnt1, eSIRegP str2, eDXRegI cnt2,
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11469
                          eAXRegI result, regD tmp1, eFlagsReg cr) %{
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11470
  predicate(((StrCompNode*)n)->encoding() == StrIntrinsicNode::LU);
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11471
  match(Set result (StrComp (Binary str1 cnt1) (Binary str2 cnt2)));
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11472
  effect(TEMP tmp1, USE_KILL str1, USE_KILL str2, USE_KILL cnt1, USE_KILL cnt2, KILL cr);
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11473
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11474
  format %{ "String Compare byte[] $str1,$cnt1,$str2,$cnt2 -> $result   // KILL $tmp1" %}
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11475
  ins_encode %{
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11476
    __ string_compare($str1$$Register, $str2$$Register,
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11477
                      $cnt1$$Register, $cnt2$$Register, $result$$Register,
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11478
                      $tmp1$$XMMRegister, StrIntrinsicNode::LU);
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11479
  %}
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11480
  ins_pipe( pipe_slow );
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11481
%}
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11482
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11483
instruct string_compareUL(eSIRegP str1, eDXRegI cnt1, eDIRegP str2, eCXRegI cnt2,
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11484
                          eAXRegI result, regD tmp1, eFlagsReg cr) %{
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11485
  predicate(((StrCompNode*)n)->encoding() == StrIntrinsicNode::UL);
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11486
  match(Set result (StrComp (Binary str1 cnt1) (Binary str2 cnt2)));
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11487
  effect(TEMP tmp1, USE_KILL str1, USE_KILL str2, USE_KILL cnt1, USE_KILL cnt2, KILL cr);
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11488
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11489
  format %{ "String Compare byte[] $str1,$cnt1,$str2,$cnt2 -> $result   // KILL $tmp1" %}
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11490
  ins_encode %{
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11491
    __ string_compare($str2$$Register, $str1$$Register,
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11492
                      $cnt2$$Register, $cnt1$$Register, $result$$Register,
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11493
                      $tmp1$$XMMRegister, StrIntrinsicNode::UL);
3905
7d725029ac85 6827605: new String intrinsics may prevent EA scalar replacement
kvn
parents: 3177
diff changeset
 11494
  %}
2348
4e71ed4c2709 6761600: Use sse 4.2 in intrinsics
cfang
parents: 2338
diff changeset
 11495
  ins_pipe( pipe_slow );
4e71ed4c2709 6761600: Use sse 4.2 in intrinsics
cfang
parents: 2338
diff changeset
 11496
%}
4e71ed4c2709 6761600: Use sse 4.2 in intrinsics
cfang
parents: 2338
diff changeset
 11497
4e71ed4c2709 6761600: Use sse 4.2 in intrinsics
cfang
parents: 2338
diff changeset
 11498
// fast string equals
3905
7d725029ac85 6827605: new String intrinsics may prevent EA scalar replacement
kvn
parents: 3177
diff changeset
 11499
instruct string_equals(eDIRegP str1, eSIRegP str2, eCXRegI cnt, eAXRegI result,
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 11500
                       regD tmp1, regD tmp2, eBXRegI tmp3, eFlagsReg cr) %{
3905
7d725029ac85 6827605: new String intrinsics may prevent EA scalar replacement
kvn
parents: 3177
diff changeset
 11501
  match(Set result (StrEquals (Binary str1 str2) cnt));
7d725029ac85 6827605: new String intrinsics may prevent EA scalar replacement
kvn
parents: 3177
diff changeset
 11502
  effect(TEMP tmp1, TEMP tmp2, USE_KILL str1, USE_KILL str2, USE_KILL cnt, KILL tmp3, KILL cr);
7d725029ac85 6827605: new String intrinsics may prevent EA scalar replacement
kvn
parents: 3177
diff changeset
 11503
7d725029ac85 6827605: new String intrinsics may prevent EA scalar replacement
kvn
parents: 3177
diff changeset
 11504
  format %{ "String Equals $str1,$str2,$cnt -> $result    // KILL $tmp1, $tmp2, $tmp3" %}
7d725029ac85 6827605: new String intrinsics may prevent EA scalar replacement
kvn
parents: 3177
diff changeset
 11505
  ins_encode %{
33628
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11506
    __ arrays_equals(false, $str1$$Register, $str2$$Register,
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11507
                     $cnt$$Register, $result$$Register, $tmp3$$Register,
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11508
                     $tmp1$$XMMRegister, $tmp2$$XMMRegister, false /* char */);
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11509
  %} 
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11510
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11511
  ins_pipe( pipe_slow );
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11512
%}
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11513
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11514
// fast search of substring with known size.
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11515
instruct string_indexof_conL(eDIRegP str1, eDXRegI cnt1, eSIRegP str2, immI int_cnt2,
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11516
                             eBXRegI result, regD vec, eAXRegI cnt2, eCXRegI tmp, eFlagsReg cr) %{
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11517
  predicate(UseSSE42Intrinsics && (((StrIndexOfNode*)n)->encoding() == StrIntrinsicNode::LL));
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11518
  match(Set result (StrIndexOf (Binary str1 cnt1) (Binary str2 int_cnt2)));
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11519
  effect(TEMP vec, USE_KILL str1, USE_KILL str2, USE_KILL cnt1, KILL cnt2, KILL tmp, KILL cr);
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11520
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11521
  format %{ "String IndexOf byte[] $str1,$cnt1,$str2,$int_cnt2 -> $result   // KILL $vec, $cnt1, $cnt2, $tmp" %}
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11522
  ins_encode %{
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11523
    int icnt2 = (int)$int_cnt2$$constant;
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11524
    if (icnt2 >= 16) {
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11525
      // IndexOf for constant substrings with size >= 16 elements
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11526
      // which don't need to be loaded through stack.
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11527
      __ string_indexofC8($str1$$Register, $str2$$Register,
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11528
                          $cnt1$$Register, $cnt2$$Register,
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11529
                          icnt2, $result$$Register,
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11530
                          $vec$$XMMRegister, $tmp$$Register, StrIntrinsicNode::LL);
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11531
    } else {
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11532
      // Small strings are loaded through stack if they cross page boundary.
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11533
      __ string_indexof($str1$$Register, $str2$$Register,
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11534
                        $cnt1$$Register, $cnt2$$Register,
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11535
                        icnt2, $result$$Register,
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11536
                        $vec$$XMMRegister, $tmp$$Register, StrIntrinsicNode::LL);
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11537
    }
3905
7d725029ac85 6827605: new String intrinsics may prevent EA scalar replacement
kvn
parents: 3177
diff changeset
 11538
  %}
7d725029ac85 6827605: new String intrinsics may prevent EA scalar replacement
kvn
parents: 3177
diff changeset
 11539
  ins_pipe( pipe_slow );
7d725029ac85 6827605: new String intrinsics may prevent EA scalar replacement
kvn
parents: 3177
diff changeset
 11540
%}
7d725029ac85 6827605: new String intrinsics may prevent EA scalar replacement
kvn
parents: 3177
diff changeset
 11541
8494
4258c78226d9 6942326: x86 code in string_indexof() could read beyond reserved heap space
kvn
parents: 8332
diff changeset
 11542
// fast search of substring with known size.
33628
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11543
instruct string_indexof_conU(eDIRegP str1, eDXRegI cnt1, eSIRegP str2, immI int_cnt2,
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11544
                             eBXRegI result, regD vec, eAXRegI cnt2, eCXRegI tmp, eFlagsReg cr) %{
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11545
  predicate(UseSSE42Intrinsics && (((StrIndexOfNode*)n)->encoding() == StrIntrinsicNode::UU));
8494
4258c78226d9 6942326: x86 code in string_indexof() could read beyond reserved heap space
kvn
parents: 8332
diff changeset
 11546
  match(Set result (StrIndexOf (Binary str1 cnt1) (Binary str2 int_cnt2)));
4258c78226d9 6942326: x86 code in string_indexof() could read beyond reserved heap space
kvn
parents: 8332
diff changeset
 11547
  effect(TEMP vec, USE_KILL str1, USE_KILL str2, USE_KILL cnt1, KILL cnt2, KILL tmp, KILL cr);
4258c78226d9 6942326: x86 code in string_indexof() could read beyond reserved heap space
kvn
parents: 8332
diff changeset
 11548
33628
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11549
  format %{ "String IndexOf char[] $str1,$cnt1,$str2,$int_cnt2 -> $result   // KILL $vec, $cnt1, $cnt2, $tmp" %}
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11550
  ins_encode %{
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11551
    int icnt2 = (int)$int_cnt2$$constant;
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11552
    if (icnt2 >= 8) {
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11553
      // IndexOf for constant substrings with size >= 8 elements
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11554
      // which don't need to be loaded through stack.
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11555
      __ string_indexofC8($str1$$Register, $str2$$Register,
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11556
                          $cnt1$$Register, $cnt2$$Register,
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11557
                          icnt2, $result$$Register,
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11558
                          $vec$$XMMRegister, $tmp$$Register, StrIntrinsicNode::UU);
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11559
    } else {
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11560
      // Small strings are loaded through stack if they cross page boundary.
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11561
      __ string_indexof($str1$$Register, $str2$$Register,
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11562
                        $cnt1$$Register, $cnt2$$Register,
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11563
                        icnt2, $result$$Register,
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11564
                        $vec$$XMMRegister, $tmp$$Register, StrIntrinsicNode::UU);
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11565
    }
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11566
  %}
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11567
  ins_pipe( pipe_slow );
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11568
%}
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11569
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11570
// fast search of substring with known size.
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11571
instruct string_indexof_conUL(eDIRegP str1, eDXRegI cnt1, eSIRegP str2, immI int_cnt2,
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11572
                             eBXRegI result, regD vec, eAXRegI cnt2, eCXRegI tmp, eFlagsReg cr) %{
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11573
  predicate(UseSSE42Intrinsics && (((StrIndexOfNode*)n)->encoding() == StrIntrinsicNode::UL));
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11574
  match(Set result (StrIndexOf (Binary str1 cnt1) (Binary str2 int_cnt2)));
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11575
  effect(TEMP vec, USE_KILL str1, USE_KILL str2, USE_KILL cnt1, KILL cnt2, KILL tmp, KILL cr);
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11576
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11577
  format %{ "String IndexOf char[] $str1,$cnt1,$str2,$int_cnt2 -> $result   // KILL $vec, $cnt1, $cnt2, $tmp" %}
8494
4258c78226d9 6942326: x86 code in string_indexof() could read beyond reserved heap space
kvn
parents: 8332
diff changeset
 11578
  ins_encode %{
4258c78226d9 6942326: x86 code in string_indexof() could read beyond reserved heap space
kvn
parents: 8332
diff changeset
 11579
    int icnt2 = (int)$int_cnt2$$constant;
4258c78226d9 6942326: x86 code in string_indexof() could read beyond reserved heap space
kvn
parents: 8332
diff changeset
 11580
    if (icnt2 >= 8) {
4258c78226d9 6942326: x86 code in string_indexof() could read beyond reserved heap space
kvn
parents: 8332
diff changeset
 11581
      // IndexOf for constant substrings with size >= 8 elements
4258c78226d9 6942326: x86 code in string_indexof() could read beyond reserved heap space
kvn
parents: 8332
diff changeset
 11582
      // which don't need to be loaded through stack.
4258c78226d9 6942326: x86 code in string_indexof() could read beyond reserved heap space
kvn
parents: 8332
diff changeset
 11583
      __ string_indexofC8($str1$$Register, $str2$$Register,
4258c78226d9 6942326: x86 code in string_indexof() could read beyond reserved heap space
kvn
parents: 8332
diff changeset
 11584
                          $cnt1$$Register, $cnt2$$Register,
4258c78226d9 6942326: x86 code in string_indexof() could read beyond reserved heap space
kvn
parents: 8332
diff changeset
 11585
                          icnt2, $result$$Register,
33628
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11586
                          $vec$$XMMRegister, $tmp$$Register, StrIntrinsicNode::UL);
8494
4258c78226d9 6942326: x86 code in string_indexof() could read beyond reserved heap space
kvn
parents: 8332
diff changeset
 11587
    } else {
4258c78226d9 6942326: x86 code in string_indexof() could read beyond reserved heap space
kvn
parents: 8332
diff changeset
 11588
      // Small strings are loaded through stack if they cross page boundary.
4258c78226d9 6942326: x86 code in string_indexof() could read beyond reserved heap space
kvn
parents: 8332
diff changeset
 11589
      __ string_indexof($str1$$Register, $str2$$Register,
4258c78226d9 6942326: x86 code in string_indexof() could read beyond reserved heap space
kvn
parents: 8332
diff changeset
 11590
                        $cnt1$$Register, $cnt2$$Register,
4258c78226d9 6942326: x86 code in string_indexof() could read beyond reserved heap space
kvn
parents: 8332
diff changeset
 11591
                        icnt2, $result$$Register,
33628
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11592
                        $vec$$XMMRegister, $tmp$$Register, StrIntrinsicNode::UL);
8494
4258c78226d9 6942326: x86 code in string_indexof() could read beyond reserved heap space
kvn
parents: 8332
diff changeset
 11593
    }
4258c78226d9 6942326: x86 code in string_indexof() could read beyond reserved heap space
kvn
parents: 8332
diff changeset
 11594
  %}
4258c78226d9 6942326: x86 code in string_indexof() could read beyond reserved heap space
kvn
parents: 8332
diff changeset
 11595
  ins_pipe( pipe_slow );
4258c78226d9 6942326: x86 code in string_indexof() could read beyond reserved heap space
kvn
parents: 8332
diff changeset
 11596
%}
4258c78226d9 6942326: x86 code in string_indexof() could read beyond reserved heap space
kvn
parents: 8332
diff changeset
 11597
33628
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11598
instruct string_indexofL(eDIRegP str1, eDXRegI cnt1, eSIRegP str2, eAXRegI cnt2,
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11599
                         eBXRegI result, regD vec, eCXRegI tmp, eFlagsReg cr) %{
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11600
  predicate(UseSSE42Intrinsics && (((StrIndexOfNode*)n)->encoding() == StrIntrinsicNode::LL));
3905
7d725029ac85 6827605: new String intrinsics may prevent EA scalar replacement
kvn
parents: 3177
diff changeset
 11601
  match(Set result (StrIndexOf (Binary str1 cnt1) (Binary str2 cnt2)));
8494
4258c78226d9 6942326: x86 code in string_indexof() could read beyond reserved heap space
kvn
parents: 8332
diff changeset
 11602
  effect(TEMP vec, USE_KILL str1, USE_KILL str2, USE_KILL cnt1, USE_KILL cnt2, KILL tmp, KILL cr);
4258c78226d9 6942326: x86 code in string_indexof() could read beyond reserved heap space
kvn
parents: 8332
diff changeset
 11603
33628
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11604
  format %{ "String IndexOf byte[] $str1,$cnt1,$str2,$cnt2 -> $result   // KILL all" %}
3905
7d725029ac85 6827605: new String intrinsics may prevent EA scalar replacement
kvn
parents: 3177
diff changeset
 11605
  ins_encode %{
7d725029ac85 6827605: new String intrinsics may prevent EA scalar replacement
kvn
parents: 3177
diff changeset
 11606
    __ string_indexof($str1$$Register, $str2$$Register,
8494
4258c78226d9 6942326: x86 code in string_indexof() could read beyond reserved heap space
kvn
parents: 8332
diff changeset
 11607
                      $cnt1$$Register, $cnt2$$Register,
4258c78226d9 6942326: x86 code in string_indexof() could read beyond reserved heap space
kvn
parents: 8332
diff changeset
 11608
                      (-1), $result$$Register,
33628
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11609
                      $vec$$XMMRegister, $tmp$$Register, StrIntrinsicNode::LL);
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11610
  %}
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11611
  ins_pipe( pipe_slow );
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11612
%}
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11613
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11614
instruct string_indexofU(eDIRegP str1, eDXRegI cnt1, eSIRegP str2, eAXRegI cnt2,
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11615
                         eBXRegI result, regD vec, eCXRegI tmp, eFlagsReg cr) %{
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11616
  predicate(UseSSE42Intrinsics && (((StrIndexOfNode*)n)->encoding() == StrIntrinsicNode::UU));
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11617
  match(Set result (StrIndexOf (Binary str1 cnt1) (Binary str2 cnt2)));
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11618
  effect(TEMP vec, USE_KILL str1, USE_KILL str2, USE_KILL cnt1, USE_KILL cnt2, KILL tmp, KILL cr);
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11619
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11620
  format %{ "String IndexOf char[] $str1,$cnt1,$str2,$cnt2 -> $result   // KILL all" %}
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11621
  ins_encode %{
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11622
    __ string_indexof($str1$$Register, $str2$$Register,
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11623
                      $cnt1$$Register, $cnt2$$Register,
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11624
                      (-1), $result$$Register,
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11625
                      $vec$$XMMRegister, $tmp$$Register, StrIntrinsicNode::UU);
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11626
  %}
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11627
  ins_pipe( pipe_slow );
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11628
%}
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11629
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11630
instruct string_indexofUL(eDIRegP str1, eDXRegI cnt1, eSIRegP str2, eAXRegI cnt2,
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11631
                         eBXRegI result, regD vec, eCXRegI tmp, eFlagsReg cr) %{
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11632
  predicate(UseSSE42Intrinsics && (((StrIndexOfNode*)n)->encoding() == StrIntrinsicNode::UL));
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11633
  match(Set result (StrIndexOf (Binary str1 cnt1) (Binary str2 cnt2)));
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11634
  effect(TEMP vec, USE_KILL str1, USE_KILL str2, USE_KILL cnt1, USE_KILL cnt2, KILL tmp, KILL cr);
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11635
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11636
  format %{ "String IndexOf char[] $str1,$cnt1,$str2,$cnt2 -> $result   // KILL all" %}
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11637
  ins_encode %{
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11638
    __ string_indexof($str1$$Register, $str2$$Register,
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11639
                      $cnt1$$Register, $cnt2$$Register,
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11640
                      (-1), $result$$Register,
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11641
                      $vec$$XMMRegister, $tmp$$Register, StrIntrinsicNode::UL);
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11642
  %}
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11643
  ins_pipe( pipe_slow );
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11644
%}
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11645
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11646
instruct string_indexofU_char(eDIRegP str1, eDXRegI cnt1, eAXRegI ch,
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11647
                              eBXRegI result, regD vec1, regD vec2, regD vec3, eCXRegI tmp, eFlagsReg cr) %{
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11648
  predicate(UseSSE42Intrinsics);
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11649
  match(Set result (StrIndexOfChar (Binary str1 cnt1) ch));
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11650
  effect(TEMP vec1, TEMP vec2, TEMP vec3, USE_KILL str1, USE_KILL cnt1, USE_KILL ch, TEMP tmp, KILL cr);
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11651
  format %{ "String IndexOf char[] $str1,$cnt1,$ch -> $result   // KILL all" %}
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11652
  ins_encode %{
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11653
    __ string_indexof_char($str1$$Register, $cnt1$$Register, $ch$$Register, $result$$Register,
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11654
                           $vec1$$XMMRegister, $vec2$$XMMRegister, $vec3$$XMMRegister, $tmp$$Register);
3905
7d725029ac85 6827605: new String intrinsics may prevent EA scalar replacement
kvn
parents: 3177
diff changeset
 11655
  %}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11656
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11657
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11658
595
a2be4c89de81 6695049: (coll) Create an x86 intrinsic for Arrays.equals
rasbold
parents: 360
diff changeset
 11659
// fast array equals
33628
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11660
instruct array_equalsB(eDIRegP ary1, eSIRegP ary2, eAXRegI result,
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11661
                       regD tmp1, regD tmp2, eCXRegI tmp3, eBXRegI tmp4, eFlagsReg cr)
3905
7d725029ac85 6827605: new String intrinsics may prevent EA scalar replacement
kvn
parents: 3177
diff changeset
 11662
%{
33628
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11663
  predicate(((AryEqNode*)n)->encoding() == StrIntrinsicNode::LL);
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11664
  match(Set result (AryEq ary1 ary2));
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11665
  effect(TEMP tmp1, TEMP tmp2, USE_KILL ary1, USE_KILL ary2, KILL tmp3, KILL tmp4, KILL cr);
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11666
  //ins_cost(300);
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11667
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11668
  format %{ "Array Equals byte[] $ary1,$ary2 -> $result   // KILL $tmp1, $tmp2, $tmp3, $tmp4" %}
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11669
  ins_encode %{
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11670
    __ arrays_equals(true, $ary1$$Register, $ary2$$Register,
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11671
                     $tmp3$$Register, $result$$Register, $tmp4$$Register,
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11672
                     $tmp1$$XMMRegister, $tmp2$$XMMRegister, false /* char */);
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11673
  %}
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11674
  ins_pipe( pipe_slow );
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11675
%}
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11676
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11677
instruct array_equalsC(eDIRegP ary1, eSIRegP ary2, eAXRegI result,
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11678
                       regD tmp1, regD tmp2, eCXRegI tmp3, eBXRegI tmp4, eFlagsReg cr)
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11679
%{
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11680
  predicate(((AryEqNode*)n)->encoding() == StrIntrinsicNode::UU);
595
a2be4c89de81 6695049: (coll) Create an x86 intrinsic for Arrays.equals
rasbold
parents: 360
diff changeset
 11681
  match(Set result (AryEq ary1 ary2));
2348
4e71ed4c2709 6761600: Use sse 4.2 in intrinsics
cfang
parents: 2338
diff changeset
 11682
  effect(TEMP tmp1, TEMP tmp2, USE_KILL ary1, USE_KILL ary2, KILL tmp3, KILL tmp4, KILL cr);
595
a2be4c89de81 6695049: (coll) Create an x86 intrinsic for Arrays.equals
rasbold
parents: 360
diff changeset
 11683
  //ins_cost(300);
a2be4c89de81 6695049: (coll) Create an x86 intrinsic for Arrays.equals
rasbold
parents: 360
diff changeset
 11684
33628
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11685
  format %{ "Array Equals char[] $ary1,$ary2 -> $result   // KILL $tmp1, $tmp2, $tmp3, $tmp4" %}
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11686
  ins_encode %{
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11687
    __ arrays_equals(true, $ary1$$Register, $ary2$$Register,
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11688
                     $tmp3$$Register, $result$$Register, $tmp4$$Register,
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11689
                     $tmp1$$XMMRegister, $tmp2$$XMMRegister, true /* char */);
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11690
  %}
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11691
  ins_pipe( pipe_slow );
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11692
%}
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11693
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11694
instruct has_negatives(eSIRegP ary1, eCXRegI len, eAXRegI result,
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11695
                      regD tmp1, regD tmp2, eBXRegI tmp3, eFlagsReg cr)
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11696
%{
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11697
  match(Set result (HasNegatives ary1 len));
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11698
  effect(TEMP tmp1, TEMP tmp2, USE_KILL ary1, USE_KILL len, KILL tmp3, KILL cr);
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11699
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11700
  format %{ "has negatives byte[] $ary1,$len -> $result   // KILL $tmp1, $tmp2, $tmp3" %}
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11701
  ins_encode %{
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11702
    __ has_negatives($ary1$$Register, $len$$Register,
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11703
                     $result$$Register, $tmp3$$Register,
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11704
                     $tmp1$$XMMRegister, $tmp2$$XMMRegister);
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11705
  %}
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11706
  ins_pipe( pipe_slow );
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11707
%}
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11708
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11709
// fast char[] to byte[] compression
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11710
instruct string_compress(eSIRegP src, eDIRegP dst, eDXRegI len, regD tmp1, regD tmp2, regD tmp3, regD tmp4,
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11711
                         eCXRegI tmp5, eAXRegI result, eFlagsReg cr) %{
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11712
  match(Set result (StrCompressedCopy src (Binary dst len)));
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11713
  effect(TEMP tmp1, TEMP tmp2, TEMP tmp3, TEMP tmp4, USE_KILL src, USE_KILL dst, USE_KILL len, KILL tmp5, KILL cr);
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11714
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11715
  format %{ "String Compress $src,$dst -> $result    // KILL RAX, RCX, RDX" %}
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11716
  ins_encode %{
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11717
    __ char_array_compress($src$$Register, $dst$$Register, $len$$Register,
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11718
                           $tmp1$$XMMRegister, $tmp2$$XMMRegister, $tmp3$$XMMRegister,
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11719
                           $tmp4$$XMMRegister, $tmp5$$Register, $result$$Register);
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11720
  %}
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11721
  ins_pipe( pipe_slow );
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11722
%}
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11723
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11724
// fast byte[] to char[] inflation
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11725
instruct string_inflate(Universe dummy, eSIRegP src, eDIRegP dst, eDXRegI len,
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11726
                        regD tmp1, eCXRegI tmp2, eFlagsReg cr) %{
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11727
  match(Set dummy (StrInflatedCopy src (Binary dst len)));
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11728
  effect(TEMP tmp1, TEMP tmp2, USE_KILL src, USE_KILL dst, USE_KILL len, KILL cr);
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11729
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11730
  format %{ "String Inflate $src,$dst    // KILL $tmp1, $tmp2" %}
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11731
  ins_encode %{
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11732
    __ byte_array_inflate($src$$Register, $dst$$Register, $len$$Register,
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33465
diff changeset
 11733
                          $tmp1$$XMMRegister, $tmp2$$Register);
3905
7d725029ac85 6827605: new String intrinsics may prevent EA scalar replacement
kvn
parents: 3177
diff changeset
 11734
  %}
595
a2be4c89de81 6695049: (coll) Create an x86 intrinsic for Arrays.equals
rasbold
parents: 360
diff changeset
 11735
  ins_pipe( pipe_slow );
a2be4c89de81 6695049: (coll) Create an x86 intrinsic for Arrays.equals
rasbold
parents: 360
diff changeset
 11736
%}
a2be4c89de81 6695049: (coll) Create an x86 intrinsic for Arrays.equals
rasbold
parents: 360
diff changeset
 11737
15242
695bb216be99 6896617: Optimize sun.nio.cs.ISO_8859_1$Encode.encodeArrayLoop() on x86
kvn
parents: 15114
diff changeset
 11738
// encode char[] to byte[] in ISO_8859_1
695bb216be99 6896617: Optimize sun.nio.cs.ISO_8859_1$Encode.encodeArrayLoop() on x86
kvn
parents: 15114
diff changeset
 11739
instruct encode_iso_array(eSIRegP src, eDIRegP dst, eDXRegI len,
695bb216be99 6896617: Optimize sun.nio.cs.ISO_8859_1$Encode.encodeArrayLoop() on x86
kvn
parents: 15114
diff changeset
 11740
                          regD tmp1, regD tmp2, regD tmp3, regD tmp4,
695bb216be99 6896617: Optimize sun.nio.cs.ISO_8859_1$Encode.encodeArrayLoop() on x86
kvn
parents: 15114
diff changeset
 11741
                          eCXRegI tmp5, eAXRegI result, eFlagsReg cr) %{
695bb216be99 6896617: Optimize sun.nio.cs.ISO_8859_1$Encode.encodeArrayLoop() on x86
kvn
parents: 15114
diff changeset
 11742
  match(Set result (EncodeISOArray src (Binary dst len)));
695bb216be99 6896617: Optimize sun.nio.cs.ISO_8859_1$Encode.encodeArrayLoop() on x86
kvn
parents: 15114
diff changeset
 11743
  effect(TEMP tmp1, TEMP tmp2, TEMP tmp3, TEMP tmp4, USE_KILL src, USE_KILL dst, USE_KILL len, KILL tmp5, KILL cr);
695bb216be99 6896617: Optimize sun.nio.cs.ISO_8859_1$Encode.encodeArrayLoop() on x86
kvn
parents: 15114
diff changeset
 11744
695bb216be99 6896617: Optimize sun.nio.cs.ISO_8859_1$Encode.encodeArrayLoop() on x86
kvn
parents: 15114
diff changeset
 11745
  format %{ "Encode array $src,$dst,$len -> $result    // KILL ECX, EDX, $tmp1, $tmp2, $tmp3, $tmp4, ESI, EDI " %}
695bb216be99 6896617: Optimize sun.nio.cs.ISO_8859_1$Encode.encodeArrayLoop() on x86
kvn
parents: 15114
diff changeset
 11746
  ins_encode %{
695bb216be99 6896617: Optimize sun.nio.cs.ISO_8859_1$Encode.encodeArrayLoop() on x86
kvn
parents: 15114
diff changeset
 11747
    __ encode_iso_array($src$$Register, $dst$$Register, $len$$Register,
695bb216be99 6896617: Optimize sun.nio.cs.ISO_8859_1$Encode.encodeArrayLoop() on x86
kvn
parents: 15114
diff changeset
 11748
                        $tmp1$$XMMRegister, $tmp2$$XMMRegister, $tmp3$$XMMRegister,
695bb216be99 6896617: Optimize sun.nio.cs.ISO_8859_1$Encode.encodeArrayLoop() on x86
kvn
parents: 15114
diff changeset
 11749
                        $tmp4$$XMMRegister, $tmp5$$Register, $result$$Register);
695bb216be99 6896617: Optimize sun.nio.cs.ISO_8859_1$Encode.encodeArrayLoop() on x86
kvn
parents: 15114
diff changeset
 11750
  %}
695bb216be99 6896617: Optimize sun.nio.cs.ISO_8859_1$Encode.encodeArrayLoop() on x86
kvn
parents: 15114
diff changeset
 11751
  ins_pipe( pipe_slow );
695bb216be99 6896617: Optimize sun.nio.cs.ISO_8859_1$Encode.encodeArrayLoop() on x86
kvn
parents: 15114
diff changeset
 11752
%}
695bb216be99 6896617: Optimize sun.nio.cs.ISO_8859_1$Encode.encodeArrayLoop() on x86
kvn
parents: 15114
diff changeset
 11753
695bb216be99 6896617: Optimize sun.nio.cs.ISO_8859_1$Encode.encodeArrayLoop() on x86
kvn
parents: 15114
diff changeset
 11754
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11755
//----------Control Flow Instructions------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11756
// Signed compare Instructions
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
 11757
instruct compI_eReg(eFlagsReg cr, rRegI op1, rRegI op2) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11758
  match(Set cr (CmpI op1 op2));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11759
  effect( DEF cr, USE op1, USE op2 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11760
  format %{ "CMP    $op1,$op2" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11761
  opcode(0x3B);  /* Opcode 3B /r */
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11762
  ins_encode( OpcP, RegReg( op1, op2) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11763
  ins_pipe( ialu_cr_reg_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11764
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11765
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
 11766
instruct compI_eReg_imm(eFlagsReg cr, rRegI op1, immI op2) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11767
  match(Set cr (CmpI op1 op2));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11768
  effect( DEF cr, USE op1 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11769
  format %{ "CMP    $op1,$op2" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11770
  opcode(0x81,0x07);  /* Opcode 81 /7 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11771
  // ins_encode( RegImm( op1, op2) );  /* Was CmpImm */
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11772
  ins_encode( OpcSErm( op1, op2 ), Con8or32( op2 ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11773
  ins_pipe( ialu_cr_reg_imm );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11774
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11775
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11776
// Cisc-spilled version of cmpI_eReg
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
 11777
instruct compI_eReg_mem(eFlagsReg cr, rRegI op1, memory op2) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11778
  match(Set cr (CmpI op1 (LoadI op2)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11779
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11780
  format %{ "CMP    $op1,$op2" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11781
  ins_cost(500);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11782
  opcode(0x3B);  /* Opcode 3B /r */
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11783
  ins_encode( OpcP, RegMem( op1, op2) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11784
  ins_pipe( ialu_cr_reg_mem );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11785
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11786
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
 11787
instruct testI_reg( eFlagsReg cr, rRegI src, immI0 zero ) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11788
  match(Set cr (CmpI src zero));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11789
  effect( DEF cr, USE src );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11790
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11791
  format %{ "TEST   $src,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11792
  opcode(0x85);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11793
  ins_encode( OpcP, RegReg( src, src ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11794
  ins_pipe( ialu_cr_reg_imm );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11795
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11796
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
 11797
instruct testI_reg_imm( eFlagsReg cr, rRegI src, immI con, immI0 zero ) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11798
  match(Set cr (CmpI (AndI src con) zero));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11799
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11800
  format %{ "TEST   $src,$con" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11801
  opcode(0xF7,0x00);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11802
  ins_encode( OpcP, RegOpc(src), Con32(con) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11803
  ins_pipe( ialu_cr_reg_imm );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11804
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11805
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
 11806
instruct testI_reg_mem( eFlagsReg cr, rRegI src, memory mem, immI0 zero ) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11807
  match(Set cr (CmpI (AndI src mem) zero));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11808
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11809
  format %{ "TEST   $src,$mem" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11810
  opcode(0x85);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11811
  ins_encode( OpcP, RegMem( src, mem ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11812
  ins_pipe( ialu_cr_reg_mem );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11813
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11814
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11815
// Unsigned compare Instructions; really, same as signed except they
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11816
// produce an eFlagsRegU instead of eFlagsReg.
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
 11817
instruct compU_eReg(eFlagsRegU cr, rRegI op1, rRegI op2) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11818
  match(Set cr (CmpU op1 op2));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11819
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11820
  format %{ "CMPu   $op1,$op2" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11821
  opcode(0x3B);  /* Opcode 3B /r */
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11822
  ins_encode( OpcP, RegReg( op1, op2) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11823
  ins_pipe( ialu_cr_reg_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11824
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11825
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
 11826
instruct compU_eReg_imm(eFlagsRegU cr, rRegI op1, immI op2) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11827
  match(Set cr (CmpU op1 op2));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11828
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11829
  format %{ "CMPu   $op1,$op2" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11830
  opcode(0x81,0x07);  /* Opcode 81 /7 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11831
  ins_encode( OpcSErm( op1, op2 ), Con8or32( op2 ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11832
  ins_pipe( ialu_cr_reg_imm );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11833
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11834
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11835
// // Cisc-spilled version of cmpU_eReg
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
 11836
instruct compU_eReg_mem(eFlagsRegU cr, rRegI op1, memory op2) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11837
  match(Set cr (CmpU op1 (LoadI op2)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11838
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11839
  format %{ "CMPu   $op1,$op2" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11840
  ins_cost(500);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11841
  opcode(0x3B);  /* Opcode 3B /r */
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11842
  ins_encode( OpcP, RegMem( op1, op2) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11843
  ins_pipe( ialu_cr_reg_mem );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11844
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11845
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11846
// // Cisc-spilled version of cmpU_eReg
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
 11847
//instruct compU_mem_eReg(eFlagsRegU cr, memory op1, rRegI op2) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11848
//  match(Set cr (CmpU (LoadI op1) op2));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11849
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11850
//  format %{ "CMPu   $op1,$op2" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11851
//  ins_cost(500);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11852
//  opcode(0x39);  /* Opcode 39 /r */
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11853
//  ins_encode( OpcP, RegMem( op1, op2) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11854
//%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11855
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
 11856
instruct testU_reg( eFlagsRegU cr, rRegI src, immI0 zero ) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11857
  match(Set cr (CmpU src zero));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11858
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11859
  format %{ "TESTu  $src,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11860
  opcode(0x85);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11861
  ins_encode( OpcP, RegReg( src, src ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11862
  ins_pipe( ialu_cr_reg_imm );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11863
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11864
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11865
// Unsigned pointer compare Instructions
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11866
instruct compP_eReg(eFlagsRegU cr, eRegP op1, eRegP op2) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11867
  match(Set cr (CmpP op1 op2));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11868
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11869
  format %{ "CMPu   $op1,$op2" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11870
  opcode(0x3B);  /* Opcode 3B /r */
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11871
  ins_encode( OpcP, RegReg( op1, op2) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11872
  ins_pipe( ialu_cr_reg_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11873
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11874
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11875
instruct compP_eReg_imm(eFlagsRegU cr, eRegP op1, immP op2) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11876
  match(Set cr (CmpP op1 op2));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11877
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11878
  format %{ "CMPu   $op1,$op2" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11879
  opcode(0x81,0x07);  /* Opcode 81 /7 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11880
  ins_encode( OpcSErm( op1, op2 ), Con8or32( op2 ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11881
  ins_pipe( ialu_cr_reg_imm );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11882
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11883
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11884
// // Cisc-spilled version of cmpP_eReg
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11885
instruct compP_eReg_mem(eFlagsRegU cr, eRegP op1, memory op2) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11886
  match(Set cr (CmpP op1 (LoadP op2)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11887
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11888
  format %{ "CMPu   $op1,$op2" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11889
  ins_cost(500);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11890
  opcode(0x3B);  /* Opcode 3B /r */
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11891
  ins_encode( OpcP, RegMem( op1, op2) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11892
  ins_pipe( ialu_cr_reg_mem );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11893
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11894
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11895
// // Cisc-spilled version of cmpP_eReg
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11896
//instruct compP_mem_eReg(eFlagsRegU cr, memory op1, eRegP op2) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11897
//  match(Set cr (CmpP (LoadP op1) op2));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11898
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11899
//  format %{ "CMPu   $op1,$op2" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11900
//  ins_cost(500);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11901
//  opcode(0x39);  /* Opcode 39 /r */
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11902
//  ins_encode( OpcP, RegMem( op1, op2) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11903
//%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11904
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11905
// Compare raw pointer (used in out-of-heap check).
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11906
// Only works because non-oop pointers must be raw pointers
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11907
// and raw pointers have no anti-dependencies.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11908
instruct compP_mem_eReg( eFlagsRegU cr, eRegP op1, memory op2 ) %{
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13485
diff changeset
 11909
  predicate( n->in(2)->in(2)->bottom_type()->reloc() == relocInfo::none );
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11910
  match(Set cr (CmpP op1 (LoadP op2)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11911
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11912
  format %{ "CMPu   $op1,$op2" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11913
  opcode(0x3B);  /* Opcode 3B /r */
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11914
  ins_encode( OpcP, RegMem( op1, op2) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11915
  ins_pipe( ialu_cr_reg_mem );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11916
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11917
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11918
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11919
// This will generate a signed flags result. This should be ok
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11920
// since any compare to a zero should be eq/neq.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11921
instruct testP_reg( eFlagsReg cr, eRegP src, immP0 zero ) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11922
  match(Set cr (CmpP src zero));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11923
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11924
  format %{ "TEST   $src,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11925
  opcode(0x85);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11926
  ins_encode( OpcP, RegReg( src, src ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11927
  ins_pipe( ialu_cr_reg_imm );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11928
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11929
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11930
// Cisc-spilled version of testP_reg
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11931
// This will generate a signed flags result. This should be ok
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11932
// since any compare to a zero should be eq/neq.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11933
instruct testP_Reg_mem( eFlagsReg cr, memory op, immI0 zero ) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11934
  match(Set cr (CmpP (LoadP op) zero));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11935
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11936
  format %{ "TEST   $op,0xFFFFFFFF" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11937
  ins_cost(500);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11938
  opcode(0xF7);               /* Opcode F7 /0 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11939
  ins_encode( OpcP, RMopc_Mem(0x00,op), Con_d32(0xFFFFFFFF) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11940
  ins_pipe( ialu_cr_reg_imm );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11941
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11942
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11943
// Yanked all unsigned pointer compare operations.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11944
// Pointer compares are done with CmpP which is already unsigned.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11945
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11946
//----------Max and Min--------------------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11947
// Min Instructions
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11948
////
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11949
//   *** Min and Max using the conditional move are slower than the
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11950
//   *** branch version on a Pentium III.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11951
// // Conditional move for min
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
 11952
//instruct cmovI_reg_lt( rRegI op2, rRegI op1, eFlagsReg cr ) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11953
//  effect( USE_DEF op2, USE op1, USE cr );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11954
//  format %{ "CMOVlt $op2,$op1\t! min" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11955
//  opcode(0x4C,0x0F);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11956
//  ins_encode( OpcS, OpcP, RegReg( op2, op1 ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11957
//  ins_pipe( pipe_cmov_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11958
//%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11959
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11960
//// Min Register with Register (P6 version)
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
 11961
//instruct minI_eReg_p6( rRegI op1, rRegI op2 ) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11962
//  predicate(VM_Version::supports_cmov() );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11963
//  match(Set op2 (MinI op1 op2));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11964
//  ins_cost(200);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11965
//  expand %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11966
//    eFlagsReg cr;
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11967
//    compI_eReg(cr,op1,op2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11968
//    cmovI_reg_lt(op2,op1,cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11969
//  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11970
//%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11971
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11972
// Min Register with Register (generic version)
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
 11973
instruct minI_eReg(rRegI dst, rRegI src, eFlagsReg flags) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11974
  match(Set dst (MinI dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11975
  effect(KILL flags);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11976
  ins_cost(300);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11977
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11978
  format %{ "MIN    $dst,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11979
  opcode(0xCC);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11980
  ins_encode( min_enc(dst,src) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11981
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11982
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11983
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11984
// Max Register with Register
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11985
//   *** Min and Max using the conditional move are slower than the
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11986
//   *** branch version on a Pentium III.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11987
// // Conditional move for max
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
 11988
//instruct cmovI_reg_gt( rRegI op2, rRegI op1, eFlagsReg cr ) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11989
//  effect( USE_DEF op2, USE op1, USE cr );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11990
//  format %{ "CMOVgt $op2,$op1\t! max" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11991
//  opcode(0x4F,0x0F);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11992
//  ins_encode( OpcS, OpcP, RegReg( op2, op1 ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11993
//  ins_pipe( pipe_cmov_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11994
//%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11995
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11996
// // Max Register with Register (P6 version)
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
 11997
//instruct maxI_eReg_p6( rRegI op1, rRegI op2 ) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11998
//  predicate(VM_Version::supports_cmov() );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11999
//  match(Set op2 (MaxI op1 op2));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12000
//  ins_cost(200);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12001
//  expand %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12002
//    eFlagsReg cr;
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12003
//    compI_eReg(cr,op1,op2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12004
//    cmovI_reg_gt(op2,op1,cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12005
//  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12006
//%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12007
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12008
// Max Register with Register (generic version)
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
 12009
instruct maxI_eReg(rRegI dst, rRegI src, eFlagsReg flags) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12010
  match(Set dst (MaxI dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12011
  effect(KILL flags);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12012
  ins_cost(300);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12013
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12014
  format %{ "MAX    $dst,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12015
  opcode(0xCC);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12016
  ins_encode( max_enc(dst,src) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12017
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12018
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12019
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12020
// ============================================================================
9446
748a37b25d10 5091921: Sign flip issues in loop optimizer
kvn
parents: 9135
diff changeset
 12021
// Counted Loop limit node which represents exact final iterator value.
748a37b25d10 5091921: Sign flip issues in loop optimizer
kvn
parents: 9135
diff changeset
 12022
// Note: the resulting value should fit into integer range since
748a37b25d10 5091921: Sign flip issues in loop optimizer
kvn
parents: 9135
diff changeset
 12023
// counted loops have limit check on overflow.
748a37b25d10 5091921: Sign flip issues in loop optimizer
kvn
parents: 9135
diff changeset
 12024
instruct loopLimit_eReg(eAXRegI limit, nadxRegI init, immI stride, eDXRegI limit_hi, nadxRegI tmp, eFlagsReg flags) %{
748a37b25d10 5091921: Sign flip issues in loop optimizer
kvn
parents: 9135
diff changeset
 12025
  match(Set limit (LoopLimit (Binary init limit) stride));
748a37b25d10 5091921: Sign flip issues in loop optimizer
kvn
parents: 9135
diff changeset
 12026
  effect(TEMP limit_hi, TEMP tmp, KILL flags);
748a37b25d10 5091921: Sign flip issues in loop optimizer
kvn
parents: 9135
diff changeset
 12027
  ins_cost(300);
748a37b25d10 5091921: Sign flip issues in loop optimizer
kvn
parents: 9135
diff changeset
 12028
748a37b25d10 5091921: Sign flip issues in loop optimizer
kvn
parents: 9135
diff changeset
 12029
  format %{ "loopLimit $init,$limit,$stride  # $limit = $init + $stride *( $limit - $init + $stride -1)/ $stride, kills $limit_hi" %}
748a37b25d10 5091921: Sign flip issues in loop optimizer
kvn
parents: 9135
diff changeset
 12030
  ins_encode %{
748a37b25d10 5091921: Sign flip issues in loop optimizer
kvn
parents: 9135
diff changeset
 12031
    int strd = (int)$stride$$constant;
748a37b25d10 5091921: Sign flip issues in loop optimizer
kvn
parents: 9135
diff changeset
 12032
    assert(strd != 1 && strd != -1, "sanity");
748a37b25d10 5091921: Sign flip issues in loop optimizer
kvn
parents: 9135
diff changeset
 12033
    int m1 = (strd > 0) ? 1 : -1;
748a37b25d10 5091921: Sign flip issues in loop optimizer
kvn
parents: 9135
diff changeset
 12034
    // Convert limit to long (EAX:EDX)
748a37b25d10 5091921: Sign flip issues in loop optimizer
kvn
parents: 9135
diff changeset
 12035
    __ cdql();
748a37b25d10 5091921: Sign flip issues in loop optimizer
kvn
parents: 9135
diff changeset
 12036
    // Convert init to long (init:tmp)
748a37b25d10 5091921: Sign flip issues in loop optimizer
kvn
parents: 9135
diff changeset
 12037
    __ movl($tmp$$Register, $init$$Register);
748a37b25d10 5091921: Sign flip issues in loop optimizer
kvn
parents: 9135
diff changeset
 12038
    __ sarl($tmp$$Register, 31);
748a37b25d10 5091921: Sign flip issues in loop optimizer
kvn
parents: 9135
diff changeset
 12039
    // $limit - $init
748a37b25d10 5091921: Sign flip issues in loop optimizer
kvn
parents: 9135
diff changeset
 12040
    __ subl($limit$$Register, $init$$Register);
748a37b25d10 5091921: Sign flip issues in loop optimizer
kvn
parents: 9135
diff changeset
 12041
    __ sbbl($limit_hi$$Register, $tmp$$Register);
748a37b25d10 5091921: Sign flip issues in loop optimizer
kvn
parents: 9135
diff changeset
 12042
    // + ($stride - 1)
748a37b25d10 5091921: Sign flip issues in loop optimizer
kvn
parents: 9135
diff changeset
 12043
    if (strd > 0) {
748a37b25d10 5091921: Sign flip issues in loop optimizer
kvn
parents: 9135
diff changeset
 12044
      __ addl($limit$$Register, (strd - 1));
748a37b25d10 5091921: Sign flip issues in loop optimizer
kvn
parents: 9135
diff changeset
 12045
      __ adcl($limit_hi$$Register, 0);
748a37b25d10 5091921: Sign flip issues in loop optimizer
kvn
parents: 9135
diff changeset
 12046
      __ movl($tmp$$Register, strd);
748a37b25d10 5091921: Sign flip issues in loop optimizer
kvn
parents: 9135
diff changeset
 12047
    } else {
748a37b25d10 5091921: Sign flip issues in loop optimizer
kvn
parents: 9135
diff changeset
 12048
      __ addl($limit$$Register, (strd + 1));
748a37b25d10 5091921: Sign flip issues in loop optimizer
kvn
parents: 9135
diff changeset
 12049
      __ adcl($limit_hi$$Register, -1);
748a37b25d10 5091921: Sign flip issues in loop optimizer
kvn
parents: 9135
diff changeset
 12050
      __ lneg($limit_hi$$Register, $limit$$Register);
748a37b25d10 5091921: Sign flip issues in loop optimizer
kvn
parents: 9135
diff changeset
 12051
      __ movl($tmp$$Register, -strd);
748a37b25d10 5091921: Sign flip issues in loop optimizer
kvn
parents: 9135
diff changeset
 12052
    }
748a37b25d10 5091921: Sign flip issues in loop optimizer
kvn
parents: 9135
diff changeset
 12053
    // signed devision: (EAX:EDX) / pos_stride
748a37b25d10 5091921: Sign flip issues in loop optimizer
kvn
parents: 9135
diff changeset
 12054
    __ idivl($tmp$$Register);
748a37b25d10 5091921: Sign flip issues in loop optimizer
kvn
parents: 9135
diff changeset
 12055
    if (strd < 0) {
748a37b25d10 5091921: Sign flip issues in loop optimizer
kvn
parents: 9135
diff changeset
 12056
      // restore sign
748a37b25d10 5091921: Sign flip issues in loop optimizer
kvn
parents: 9135
diff changeset
 12057
      __ negl($tmp$$Register);
748a37b25d10 5091921: Sign flip issues in loop optimizer
kvn
parents: 9135
diff changeset
 12058
    }
748a37b25d10 5091921: Sign flip issues in loop optimizer
kvn
parents: 9135
diff changeset
 12059
    // (EAX) * stride
748a37b25d10 5091921: Sign flip issues in loop optimizer
kvn
parents: 9135
diff changeset
 12060
    __ mull($tmp$$Register);
748a37b25d10 5091921: Sign flip issues in loop optimizer
kvn
parents: 9135
diff changeset
 12061
    // + init (ignore upper bits)
748a37b25d10 5091921: Sign flip issues in loop optimizer
kvn
parents: 9135
diff changeset
 12062
    __ addl($limit$$Register, $init$$Register);
748a37b25d10 5091921: Sign flip issues in loop optimizer
kvn
parents: 9135
diff changeset
 12063
  %}
748a37b25d10 5091921: Sign flip issues in loop optimizer
kvn
parents: 9135
diff changeset
 12064
  ins_pipe( pipe_slow );
748a37b25d10 5091921: Sign flip issues in loop optimizer
kvn
parents: 9135
diff changeset
 12065
%}
748a37b25d10 5091921: Sign flip issues in loop optimizer
kvn
parents: 9135
diff changeset
 12066
748a37b25d10 5091921: Sign flip issues in loop optimizer
kvn
parents: 9135
diff changeset
 12067
// ============================================================================
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12068
// Branch Instructions
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12069
// Jump Table
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
 12070
instruct jumpXtnd(rRegI switch_val) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12071
  match(Jump switch_val);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12072
  ins_cost(350);
7433
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
 12073
  format %{  "JMP    [$constantaddress](,$switch_val,1)\n\t" %}
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
 12074
  ins_encode %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12075
    // Jump to Address(table_base + switch_reg)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12076
    Address index(noreg, $switch_val$$Register, Address::times_1);
7433
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7121
diff changeset
 12077
    __ jump(ArrayAddress($constantaddress, index));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12078
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12079
  ins_pipe(pipe_jmp);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12080
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12081
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12082
// Jump Direct - Label defines a relative address from JMP+1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12083
instruct jmpDir(label labl) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12084
  match(Goto);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12085
  effect(USE labl);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12086
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12087
  ins_cost(300);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12088
  format %{ "JMP    $labl" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12089
  size(5);
10264
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
 12090
  ins_encode %{
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
 12091
    Label* L = $labl$$label;
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
 12092
    __ jmp(*L, false); // Always long jump
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
 12093
  %}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12094
  ins_pipe( pipe_jmp );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12095
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12096
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12097
// Jump Direct Conditional - Label defines a relative address from Jcc+1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12098
instruct jmpCon(cmpOp cop, eFlagsReg cr, label labl) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12099
  match(If cop cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12100
  effect(USE labl);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12101
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12102
  ins_cost(300);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12103
  format %{ "J$cop    $labl" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12104
  size(6);
10264
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
 12105
  ins_encode %{
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
 12106
    Label* L = $labl$$label;
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
 12107
    __ jcc((Assembler::Condition)($cop$$cmpcode), *L, false); // Always long jump
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
 12108
  %}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12109
  ins_pipe( pipe_jcc );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12110
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12111
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12112
// Jump Direct Conditional - Label defines a relative address from Jcc+1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12113
instruct jmpLoopEnd(cmpOp cop, eFlagsReg cr, label labl) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12114
  match(CountedLoopEnd cop cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12115
  effect(USE labl);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12116
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12117
  ins_cost(300);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12118
  format %{ "J$cop    $labl\t# Loop end" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12119
  size(6);
10264
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
 12120
  ins_encode %{
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
 12121
    Label* L = $labl$$label;
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
 12122
    __ jcc((Assembler::Condition)($cop$$cmpcode), *L, false); // Always long jump
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
 12123
  %}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12124
  ins_pipe( pipe_jcc );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12125
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12126
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12127
// Jump Direct Conditional - Label defines a relative address from Jcc+1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12128
instruct jmpLoopEndU(cmpOpU cop, eFlagsRegU cmp, label labl) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12129
  match(CountedLoopEnd cop cmp);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12130
  effect(USE labl);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12131
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12132
  ins_cost(300);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12133
  format %{ "J$cop,u  $labl\t# Loop end" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12134
  size(6);
10264
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
 12135
  ins_encode %{
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
 12136
    Label* L = $labl$$label;
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
 12137
    __ jcc((Assembler::Condition)($cop$$cmpcode), *L, false); // Always long jump
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
 12138
  %}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12139
  ins_pipe( pipe_jcc );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12140
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12141
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12142
instruct jmpLoopEndUCF(cmpOpUCF cop, eFlagsRegUCF cmp, label labl) %{
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12143
  match(CountedLoopEnd cop cmp);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12144
  effect(USE labl);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12145
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12146
  ins_cost(200);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12147
  format %{ "J$cop,u  $labl\t# Loop end" %}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12148
  size(6);
10264
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
 12149
  ins_encode %{
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
 12150
    Label* L = $labl$$label;
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
 12151
    __ jcc((Assembler::Condition)($cop$$cmpcode), *L, false); // Always long jump
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
 12152
  %}
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12153
  ins_pipe( pipe_jcc );
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12154
%}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12155
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12156
// Jump Direct Conditional - using unsigned comparison
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12157
instruct jmpConU(cmpOpU cop, eFlagsRegU cmp, label labl) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12158
  match(If cop cmp);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12159
  effect(USE labl);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12160
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12161
  ins_cost(300);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12162
  format %{ "J$cop,u  $labl" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12163
  size(6);
10264
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
 12164
  ins_encode %{
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
 12165
    Label* L = $labl$$label;
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
 12166
    __ jcc((Assembler::Condition)($cop$$cmpcode), *L, false); // Always long jump
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
 12167
  %}
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12168
  ins_pipe(pipe_jcc);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12169
%}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12170
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12171
instruct jmpConUCF(cmpOpUCF cop, eFlagsRegUCF cmp, label labl) %{
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12172
  match(If cop cmp);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12173
  effect(USE labl);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12174
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12175
  ins_cost(200);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12176
  format %{ "J$cop,u  $labl" %}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12177
  size(6);
10264
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
 12178
  ins_encode %{
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
 12179
    Label* L = $labl$$label;
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
 12180
    __ jcc((Assembler::Condition)($cop$$cmpcode), *L, false); // Always long jump
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
 12181
  %}
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12182
  ins_pipe(pipe_jcc);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12183
%}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12184
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12185
instruct jmpConUCF2(cmpOpUCF2 cop, eFlagsRegUCF cmp, label labl) %{
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12186
  match(If cop cmp);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12187
  effect(USE labl);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12188
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12189
  ins_cost(200);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12190
  format %{ $$template
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12191
    if ($cop$$cmpcode == Assembler::notEqual) {
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12192
      $$emit$$"JP,u   $labl\n\t"
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12193
      $$emit$$"J$cop,u   $labl"
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12194
    } else {
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12195
      $$emit$$"JP,u   done\n\t"
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12196
      $$emit$$"J$cop,u   $labl\n\t"
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12197
      $$emit$$"done:"
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12198
    }
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12199
  %}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12200
  ins_encode %{
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12201
    Label* l = $labl$$label;
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12202
    if ($cop$$cmpcode == Assembler::notEqual) {
10264
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
 12203
      __ jcc(Assembler::parity, *l, false);
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
 12204
      __ jcc(Assembler::notEqual, *l, false);
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12205
    } else if ($cop$$cmpcode == Assembler::equal) {
10264
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
 12206
      Label done;
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
 12207
      __ jccb(Assembler::parity, done);
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
 12208
      __ jcc(Assembler::equal, *l, false);
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
 12209
      __ bind(done);
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12210
    } else {
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12211
       ShouldNotReachHere();
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12212
    }
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12213
  %}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12214
  ins_pipe(pipe_jcc);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12215
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12216
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12217
// ============================================================================
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12218
// The 2nd slow-half of a subtype check.  Scan the subklass's 2ndary superklass
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12219
// array for an instance of the superklass.  Set a hidden internal cache on a
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12220
// hit (cache is checked with exposed code in gen_subtype_check()).  Return
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12221
// NZ for a miss or zero for a hit.  The encoding ALSO sets flags.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12222
instruct partialSubtypeCheck( eDIRegP result, eSIRegP sub, eAXRegP super, eCXRegI rcx, eFlagsReg cr ) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12223
  match(Set result (PartialSubtypeCheck sub super));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12224
  effect( KILL rcx, KILL cr );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12225
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12226
  ins_cost(1100);  // slightly larger than the next version
2256
82d4e10b7c6b 6813212: factor duplicated assembly code for general subclass check (for 6655638)
jrose
parents: 2255
diff changeset
 12227
  format %{ "MOV    EDI,[$sub+Klass::secondary_supers]\n\t"
13952
e3cf184080bc 8000213: NPG: Should have renamed arrayKlass and typeArrayKlass
coleenp
parents: 13886
diff changeset
 12228
            "MOV    ECX,[EDI+ArrayKlass::length]\t# length to scan\n\t"
e3cf184080bc 8000213: NPG: Should have renamed arrayKlass and typeArrayKlass
coleenp
parents: 13886
diff changeset
 12229
            "ADD    EDI,ArrayKlass::base_offset\t# Skip to start of data; set NZ in case count is zero\n\t"
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12230
            "REPNE SCASD\t# Scan *EDI++ for a match with EAX while CX-- != 0\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12231
            "JNE,s  miss\t\t# Missed: EDI not-zero\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12232
            "MOV    [$sub+Klass::secondary_super_cache],$super\t# Hit: update cache\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12233
            "XOR    $result,$result\t\t Hit: EDI zero\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12234
     "miss:\t" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12235
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12236
  opcode(0x1); // Force a XOR of EDI
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12237
  ins_encode( enc_PartialSubtypeCheck() );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12238
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12239
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12240
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12241
instruct partialSubtypeCheck_vs_Zero( eFlagsReg cr, eSIRegP sub, eAXRegP super, eCXRegI rcx, eDIRegP result, immP0 zero ) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12242
  match(Set cr (CmpP (PartialSubtypeCheck sub super) zero));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12243
  effect( KILL rcx, KILL result );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12244
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12245
  ins_cost(1000);
2256
82d4e10b7c6b 6813212: factor duplicated assembly code for general subclass check (for 6655638)
jrose
parents: 2255
diff changeset
 12246
  format %{ "MOV    EDI,[$sub+Klass::secondary_supers]\n\t"
13952
e3cf184080bc 8000213: NPG: Should have renamed arrayKlass and typeArrayKlass
coleenp
parents: 13886
diff changeset
 12247
            "MOV    ECX,[EDI+ArrayKlass::length]\t# length to scan\n\t"
e3cf184080bc 8000213: NPG: Should have renamed arrayKlass and typeArrayKlass
coleenp
parents: 13886
diff changeset
 12248
            "ADD    EDI,ArrayKlass::base_offset\t# Skip to start of data; set NZ in case count is zero\n\t"
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12249
            "REPNE SCASD\t# Scan *EDI++ for a match with EAX while CX-- != 0\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12250
            "JNE,s  miss\t\t# Missed: flags NZ\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12251
            "MOV    [$sub+Klass::secondary_super_cache],$super\t# Hit: update cache, flags Z\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12252
     "miss:\t" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12253
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12254
  opcode(0x0);  // No need to XOR EDI
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12255
  ins_encode( enc_PartialSubtypeCheck() );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12256
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12257
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12258
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12259
// ============================================================================
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12260
// Branch Instructions -- short offset versions
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12261
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12262
// These instructions are used to replace jumps of a long offset (the default
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12263
// match) with jumps of a shorter offset.  These instructions are all tagged
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12264
// with the ins_short_branch attribute, which causes the ADLC to suppress the
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12265
// match rules in general matching.  Instead, the ADLC generates a conversion
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12266
// method in the MachNode which can be used to do in-place replacement of the
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12267
// long variant with the shorter variant.  The compiler will determine if a
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12268
// branch can be taken by the is_short_branch_offset() predicate in the machine
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12269
// specific code section of the file.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12270
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12271
// Jump Direct - Label defines a relative address from JMP+1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12272
instruct jmpDir_short(label labl) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12273
  match(Goto);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12274
  effect(USE labl);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12275
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12276
  ins_cost(300);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12277
  format %{ "JMP,s  $labl" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12278
  size(2);
10264
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
 12279
  ins_encode %{
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
 12280
    Label* L = $labl$$label;
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
 12281
    __ jmpb(*L);
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
 12282
  %}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12283
  ins_pipe( pipe_jmp );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12284
  ins_short_branch(1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12285
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12286
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12287
// Jump Direct Conditional - Label defines a relative address from Jcc+1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12288
instruct jmpCon_short(cmpOp cop, eFlagsReg cr, label labl) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12289
  match(If cop cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12290
  effect(USE labl);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12291
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12292
  ins_cost(300);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12293
  format %{ "J$cop,s  $labl" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12294
  size(2);
10264
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
 12295
  ins_encode %{
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
 12296
    Label* L = $labl$$label;
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
 12297
    __ jccb((Assembler::Condition)($cop$$cmpcode), *L);
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
 12298
  %}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12299
  ins_pipe( pipe_jcc );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12300
  ins_short_branch(1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12301
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12302
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12303
// Jump Direct Conditional - Label defines a relative address from Jcc+1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12304
instruct jmpLoopEnd_short(cmpOp cop, eFlagsReg cr, label labl) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12305
  match(CountedLoopEnd cop cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12306
  effect(USE labl);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12307
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12308
  ins_cost(300);
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12309
  format %{ "J$cop,s  $labl\t# Loop end" %}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12310
  size(2);
10264
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
 12311
  ins_encode %{
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
 12312
    Label* L = $labl$$label;
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
 12313
    __ jccb((Assembler::Condition)($cop$$cmpcode), *L);
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
 12314
  %}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12315
  ins_pipe( pipe_jcc );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12316
  ins_short_branch(1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12317
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12318
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12319
// Jump Direct Conditional - Label defines a relative address from Jcc+1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12320
instruct jmpLoopEndU_short(cmpOpU cop, eFlagsRegU cmp, label labl) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12321
  match(CountedLoopEnd cop cmp);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12322
  effect(USE labl);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12323
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12324
  ins_cost(300);
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12325
  format %{ "J$cop,us $labl\t# Loop end" %}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12326
  size(2);
10264
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
 12327
  ins_encode %{
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
 12328
    Label* L = $labl$$label;
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
 12329
    __ jccb((Assembler::Condition)($cop$$cmpcode), *L);
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
 12330
  %}
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12331
  ins_pipe( pipe_jcc );
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12332
  ins_short_branch(1);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12333
%}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12334
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12335
instruct jmpLoopEndUCF_short(cmpOpUCF cop, eFlagsRegUCF cmp, label labl) %{
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12336
  match(CountedLoopEnd cop cmp);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12337
  effect(USE labl);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12338
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12339
  ins_cost(300);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12340
  format %{ "J$cop,us $labl\t# Loop end" %}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12341
  size(2);
10264
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
 12342
  ins_encode %{
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
 12343
    Label* L = $labl$$label;
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
 12344
    __ jccb((Assembler::Condition)($cop$$cmpcode), *L);
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
 12345
  %}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12346
  ins_pipe( pipe_jcc );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12347
  ins_short_branch(1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12348
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12349
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12350
// Jump Direct Conditional - using unsigned comparison
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12351
instruct jmpConU_short(cmpOpU cop, eFlagsRegU cmp, label labl) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12352
  match(If cop cmp);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12353
  effect(USE labl);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12354
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12355
  ins_cost(300);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12356
  format %{ "J$cop,us $labl" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12357
  size(2);
10264
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
 12358
  ins_encode %{
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
 12359
    Label* L = $labl$$label;
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
 12360
    __ jccb((Assembler::Condition)($cop$$cmpcode), *L);
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
 12361
  %}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12362
  ins_pipe( pipe_jcc );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12363
  ins_short_branch(1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12364
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12365
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12366
instruct jmpConUCF_short(cmpOpUCF cop, eFlagsRegUCF cmp, label labl) %{
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12367
  match(If cop cmp);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12368
  effect(USE labl);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12369
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12370
  ins_cost(300);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12371
  format %{ "J$cop,us $labl" %}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12372
  size(2);
10264
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
 12373
  ins_encode %{
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
 12374
    Label* L = $labl$$label;
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
 12375
    __ jccb((Assembler::Condition)($cop$$cmpcode), *L);
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
 12376
  %}
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12377
  ins_pipe( pipe_jcc );
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12378
  ins_short_branch(1);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12379
%}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12380
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12381
instruct jmpConUCF2_short(cmpOpUCF2 cop, eFlagsRegUCF cmp, label labl) %{
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12382
  match(If cop cmp);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12383
  effect(USE labl);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12384
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12385
  ins_cost(300);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12386
  format %{ $$template
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12387
    if ($cop$$cmpcode == Assembler::notEqual) {
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12388
      $$emit$$"JP,u,s   $labl\n\t"
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12389
      $$emit$$"J$cop,u,s   $labl"
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12390
    } else {
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12391
      $$emit$$"JP,u,s   done\n\t"
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12392
      $$emit$$"J$cop,u,s  $labl\n\t"
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12393
      $$emit$$"done:"
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12394
    }
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12395
  %}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12396
  size(4);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12397
  ins_encode %{
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12398
    Label* l = $labl$$label;
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12399
    if ($cop$$cmpcode == Assembler::notEqual) {
10264
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
 12400
      __ jccb(Assembler::parity, *l);
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
 12401
      __ jccb(Assembler::notEqual, *l);
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12402
    } else if ($cop$$cmpcode == Assembler::equal) {
10264
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
 12403
      Label done;
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
 12404
      __ jccb(Assembler::parity, done);
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
 12405
      __ jccb(Assembler::equal, *l);
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
 12406
      __ bind(done);
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12407
    } else {
10264
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
 12408
       ShouldNotReachHere();
6879f93d268d 7063629: use cbcond in C2 generated code on T4
kvn
parents: 10262
diff changeset
 12409
    }
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12410
  %}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12411
  ins_pipe(pipe_jcc);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12412
  ins_short_branch(1);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12413
%}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12414
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12415
// ============================================================================
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12416
// Long Compare
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12417
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12418
// Currently we hold longs in 2 registers.  Comparing such values efficiently
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12419
// is tricky.  The flavor of compare used depends on whether we are testing
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12420
// for LT, LE, or EQ.  For a simple LT test we can check just the sign bit.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12421
// The GE test is the negated LT test.  The LE test can be had by commuting
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12422
// the operands (yielding a GE test) and then negating; negate again for the
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12423
// GT test.  The EQ test is done by ORcc'ing the high and low halves, and the
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12424
// NE test is negated from that.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12425
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12426
// Due to a shortcoming in the ADLC, it mixes up expressions like:
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12427
// (foo (CmpI (CmpL X Y) 0)) and (bar (CmpI (CmpL X 0L) 0)).  Note the
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12428
// difference between 'Y' and '0L'.  The tree-matches for the CmpI sections
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12429
// are collapsed internally in the ADLC's dfa-gen code.  The match for
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12430
// (CmpI (CmpL X Y) 0) is silently replaced with (CmpI (CmpL X 0L) 0) and the
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12431
// foo match ends up with the wrong leaf.  One fix is to not match both
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12432
// reg-reg and reg-zero forms of long-compare.  This is unfortunate because
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12433
// both forms beat the trinary form of long-compare and both are very useful
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12434
// on Intel which has so few registers.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12435
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12436
// Manifest a CmpL result in an integer register.  Very painful.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12437
// This is the test to avoid.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12438
instruct cmpL3_reg_reg(eSIRegI dst, eRegL src1, eRegL src2, eFlagsReg flags ) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12439
  match(Set dst (CmpL3 src1 src2));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12440
  effect( KILL flags );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12441
  ins_cost(1000);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12442
  format %{ "XOR    $dst,$dst\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12443
            "CMP    $src1.hi,$src2.hi\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12444
            "JLT,s  m_one\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12445
            "JGT,s  p_one\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12446
            "CMP    $src1.lo,$src2.lo\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12447
            "JB,s   m_one\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12448
            "JEQ,s  done\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12449
    "p_one:\tINC    $dst\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12450
            "JMP,s  done\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12451
    "m_one:\tDEC    $dst\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12452
     "done:" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12453
  ins_encode %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12454
    Label p_one, m_one, done;
1066
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
 12455
    __ xorptr($dst$$Register, $dst$$Register);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12456
    __ cmpl(HIGH_FROM_LOW($src1$$Register), HIGH_FROM_LOW($src2$$Register));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12457
    __ jccb(Assembler::less,    m_one);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12458
    __ jccb(Assembler::greater, p_one);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12459
    __ cmpl($src1$$Register, $src2$$Register);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12460
    __ jccb(Assembler::below,   m_one);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12461
    __ jccb(Assembler::equal,   done);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12462
    __ bind(p_one);
1066
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
 12463
    __ incrementl($dst$$Register);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12464
    __ jmpb(done);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12465
    __ bind(m_one);
1066
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
 12466
    __ decrementl($dst$$Register);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12467
    __ bind(done);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12468
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12469
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12470
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12471
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12472
//======
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12473
// Manifest a CmpL result in the normal flags.  Only good for LT or GE
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12474
// compares.  Can be used for LE or GT compares by reversing arguments.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12475
// NOT GOOD FOR EQ/NE tests.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12476
instruct cmpL_zero_flags_LTGE( flagsReg_long_LTGE flags, eRegL src, immL0 zero ) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12477
  match( Set flags (CmpL src zero ));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12478
  ins_cost(100);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12479
  format %{ "TEST   $src.hi,$src.hi" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12480
  opcode(0x85);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12481
  ins_encode( OpcP, RegReg_Hi2( src, src ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12482
  ins_pipe( ialu_cr_reg_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12483
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12484
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12485
// Manifest a CmpL result in the normal flags.  Only good for LT or GE
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12486
// compares.  Can be used for LE or GT compares by reversing arguments.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12487
// NOT GOOD FOR EQ/NE tests.
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
 12488
instruct cmpL_reg_flags_LTGE( flagsReg_long_LTGE flags, eRegL src1, eRegL src2, rRegI tmp ) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12489
  match( Set flags (CmpL src1 src2 ));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12490
  effect( TEMP tmp );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12491
  ins_cost(300);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12492
  format %{ "CMP    $src1.lo,$src2.lo\t! Long compare; set flags for low bits\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12493
            "MOV    $tmp,$src1.hi\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12494
            "SBB    $tmp,$src2.hi\t! Compute flags for long compare" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12495
  ins_encode( long_cmp_flags2( src1, src2, tmp ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12496
  ins_pipe( ialu_cr_reg_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12497
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12498
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12499
// Long compares reg < zero/req OR reg >= zero/req.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12500
// Just a wrapper for a normal branch, plus the predicate test.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12501
instruct cmpL_LTGE(cmpOp cmp, flagsReg_long_LTGE flags, label labl) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12502
  match(If cmp flags);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12503
  effect(USE labl);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12504
  predicate( _kids[0]->_leaf->as_Bool()->_test._test == BoolTest::lt || _kids[0]->_leaf->as_Bool()->_test._test == BoolTest::ge );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12505
  expand %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12506
    jmpCon(cmp,flags,labl);    // JLT or JGE...
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12507
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12508
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12509
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12510
// Compare 2 longs and CMOVE longs.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12511
instruct cmovLL_reg_LTGE(cmpOp cmp, flagsReg_long_LTGE flags, eRegL dst, eRegL src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12512
  match(Set dst (CMoveL (Binary cmp flags) (Binary dst src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12513
  predicate(VM_Version::supports_cmov() && ( _kids[0]->_kids[0]->_leaf->as_Bool()->_test._test == BoolTest::lt || _kids[0]->_kids[0]->_leaf->as_Bool()->_test._test == BoolTest::ge ));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12514
  ins_cost(400);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12515
  format %{ "CMOV$cmp $dst.lo,$src.lo\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12516
            "CMOV$cmp $dst.hi,$src.hi" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12517
  opcode(0x0F,0x40);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12518
  ins_encode( enc_cmov(cmp), RegReg_Lo2( dst, src ), enc_cmov(cmp), RegReg_Hi2( dst, src ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12519
  ins_pipe( pipe_cmov_reg_long );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12520
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12521
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12522
instruct cmovLL_mem_LTGE(cmpOp cmp, flagsReg_long_LTGE flags, eRegL dst, load_long_memory src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12523
  match(Set dst (CMoveL (Binary cmp flags) (Binary dst (LoadL src))));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12524
  predicate(VM_Version::supports_cmov() && ( _kids[0]->_kids[0]->_leaf->as_Bool()->_test._test == BoolTest::lt || _kids[0]->_kids[0]->_leaf->as_Bool()->_test._test == BoolTest::ge ));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12525
  ins_cost(500);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12526
  format %{ "CMOV$cmp $dst.lo,$src.lo\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12527
            "CMOV$cmp $dst.hi,$src.hi" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12528
  opcode(0x0F,0x40);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12529
  ins_encode( enc_cmov(cmp), RegMem(dst, src), enc_cmov(cmp), RegMem_Hi(dst, src) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12530
  ins_pipe( pipe_cmov_reg_long );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12531
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12532
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12533
// Compare 2 longs and CMOVE ints.
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
 12534
instruct cmovII_reg_LTGE(cmpOp cmp, flagsReg_long_LTGE flags, rRegI dst, rRegI src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12535
  predicate(VM_Version::supports_cmov() && ( _kids[0]->_kids[0]->_leaf->as_Bool()->_test._test == BoolTest::lt || _kids[0]->_kids[0]->_leaf->as_Bool()->_test._test == BoolTest::ge ));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12536
  match(Set dst (CMoveI (Binary cmp flags) (Binary dst src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12537
  ins_cost(200);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12538
  format %{ "CMOV$cmp $dst,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12539
  opcode(0x0F,0x40);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12540
  ins_encode( enc_cmov(cmp), RegReg( dst, src ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12541
  ins_pipe( pipe_cmov_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12542
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12543
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
 12544
instruct cmovII_mem_LTGE(cmpOp cmp, flagsReg_long_LTGE flags, rRegI dst, memory src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12545
  predicate(VM_Version::supports_cmov() && ( _kids[0]->_kids[0]->_leaf->as_Bool()->_test._test == BoolTest::lt || _kids[0]->_kids[0]->_leaf->as_Bool()->_test._test == BoolTest::ge ));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12546
  match(Set dst (CMoveI (Binary cmp flags) (Binary dst (LoadI src))));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12547
  ins_cost(250);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12548
  format %{ "CMOV$cmp $dst,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12549
  opcode(0x0F,0x40);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12550
  ins_encode( enc_cmov(cmp), RegMem( dst, src ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12551
  ins_pipe( pipe_cmov_mem );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12552
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12553
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12554
// Compare 2 longs and CMOVE ints.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12555
instruct cmovPP_reg_LTGE(cmpOp cmp, flagsReg_long_LTGE flags, eRegP dst, eRegP src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12556
  predicate(VM_Version::supports_cmov() && ( _kids[0]->_kids[0]->_leaf->as_Bool()->_test._test == BoolTest::lt || _kids[0]->_kids[0]->_leaf->as_Bool()->_test._test == BoolTest::ge ));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12557
  match(Set dst (CMoveP (Binary cmp flags) (Binary dst src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12558
  ins_cost(200);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12559
  format %{ "CMOV$cmp $dst,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12560
  opcode(0x0F,0x40);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12561
  ins_encode( enc_cmov(cmp), RegReg( dst, src ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12562
  ins_pipe( pipe_cmov_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12563
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12564
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12565
// Compare 2 longs and CMOVE doubles
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 12566
instruct cmovDDPR_reg_LTGE(cmpOp cmp, flagsReg_long_LTGE flags, regDPR dst, regDPR src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12567
  predicate( UseSSE<=1 && _kids[0]->_kids[0]->_leaf->as_Bool()->_test._test == BoolTest::lt || _kids[0]->_kids[0]->_leaf->as_Bool()->_test._test == BoolTest::ge );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12568
  match(Set dst (CMoveD (Binary cmp flags) (Binary dst src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12569
  ins_cost(200);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12570
  expand %{
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 12571
    fcmovDPR_regS(cmp,flags,dst,src);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12572
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12573
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12574
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12575
// Compare 2 longs and CMOVE doubles
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 12576
instruct cmovDD_reg_LTGE(cmpOp cmp, flagsReg_long_LTGE flags, regD dst, regD src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12577
  predicate( UseSSE>=2 && _kids[0]->_kids[0]->_leaf->as_Bool()->_test._test == BoolTest::lt || _kids[0]->_kids[0]->_leaf->as_Bool()->_test._test == BoolTest::ge );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12578
  match(Set dst (CMoveD (Binary cmp flags) (Binary dst src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12579
  ins_cost(200);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12580
  expand %{
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 12581
    fcmovD_regS(cmp,flags,dst,src);
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 12582
  %}
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 12583
%}
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 12584
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 12585
instruct cmovFFPR_reg_LTGE(cmpOp cmp, flagsReg_long_LTGE flags, regFPR dst, regFPR src) %{
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 12586
  predicate( UseSSE==0 && _kids[0]->_kids[0]->_leaf->as_Bool()->_test._test == BoolTest::lt || _kids[0]->_kids[0]->_leaf->as_Bool()->_test._test == BoolTest::ge );
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 12587
  match(Set dst (CMoveF (Binary cmp flags) (Binary dst src)));
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 12588
  ins_cost(200);
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 12589
  expand %{
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 12590
    fcmovFPR_regS(cmp,flags,dst,src);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12591
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12592
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12593
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12594
instruct cmovFF_reg_LTGE(cmpOp cmp, flagsReg_long_LTGE flags, regF dst, regF src) %{
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 12595
  predicate( UseSSE>=1 && _kids[0]->_kids[0]->_leaf->as_Bool()->_test._test == BoolTest::lt || _kids[0]->_kids[0]->_leaf->as_Bool()->_test._test == BoolTest::ge );
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12596
  match(Set dst (CMoveF (Binary cmp flags) (Binary dst src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12597
  ins_cost(200);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12598
  expand %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12599
    fcmovF_regS(cmp,flags,dst,src);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12600
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12601
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12602
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12603
//======
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12604
// Manifest a CmpL result in the normal flags.  Only good for EQ/NE compares.
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
 12605
instruct cmpL_zero_flags_EQNE( flagsReg_long_EQNE flags, eRegL src, immL0 zero, rRegI tmp ) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12606
  match( Set flags (CmpL src zero ));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12607
  effect(TEMP tmp);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12608
  ins_cost(200);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12609
  format %{ "MOV    $tmp,$src.lo\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12610
            "OR     $tmp,$src.hi\t! Long is EQ/NE 0?" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12611
  ins_encode( long_cmp_flags0( src, tmp ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12612
  ins_pipe( ialu_reg_reg_long );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12613
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12614
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12615
// Manifest a CmpL result in the normal flags.  Only good for EQ/NE compares.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12616
instruct cmpL_reg_flags_EQNE( flagsReg_long_EQNE flags, eRegL src1, eRegL src2 ) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12617
  match( Set flags (CmpL src1 src2 ));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12618
  ins_cost(200+300);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12619
  format %{ "CMP    $src1.lo,$src2.lo\t! Long compare; set flags for low bits\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12620
            "JNE,s  skip\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12621
            "CMP    $src1.hi,$src2.hi\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12622
     "skip:\t" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12623
  ins_encode( long_cmp_flags1( src1, src2 ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12624
  ins_pipe( ialu_cr_reg_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12625
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12626
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12627
// Long compare reg == zero/reg OR reg != zero/reg
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12628
// Just a wrapper for a normal branch, plus the predicate test.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12629
instruct cmpL_EQNE(cmpOp cmp, flagsReg_long_EQNE flags, label labl) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12630
  match(If cmp flags);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12631
  effect(USE labl);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12632
  predicate( _kids[0]->_leaf->as_Bool()->_test._test == BoolTest::eq || _kids[0]->_leaf->as_Bool()->_test._test == BoolTest::ne );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12633
  expand %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12634
    jmpCon(cmp,flags,labl);    // JEQ or JNE...
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12635
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12636
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12637
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12638
// Compare 2 longs and CMOVE longs.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12639
instruct cmovLL_reg_EQNE(cmpOp cmp, flagsReg_long_EQNE flags, eRegL dst, eRegL src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12640
  match(Set dst (CMoveL (Binary cmp flags) (Binary dst src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12641
  predicate(VM_Version::supports_cmov() && ( _kids[0]->_kids[0]->_leaf->as_Bool()->_test._test == BoolTest::eq || _kids[0]->_kids[0]->_leaf->as_Bool()->_test._test == BoolTest::ne ));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12642
  ins_cost(400);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12643
  format %{ "CMOV$cmp $dst.lo,$src.lo\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12644
            "CMOV$cmp $dst.hi,$src.hi" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12645
  opcode(0x0F,0x40);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12646
  ins_encode( enc_cmov(cmp), RegReg_Lo2( dst, src ), enc_cmov(cmp), RegReg_Hi2( dst, src ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12647
  ins_pipe( pipe_cmov_reg_long );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12648
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12649
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12650
instruct cmovLL_mem_EQNE(cmpOp cmp, flagsReg_long_EQNE flags, eRegL dst, load_long_memory src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12651
  match(Set dst (CMoveL (Binary cmp flags) (Binary dst (LoadL src))));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12652
  predicate(VM_Version::supports_cmov() && ( _kids[0]->_kids[0]->_leaf->as_Bool()->_test._test == BoolTest::eq || _kids[0]->_kids[0]->_leaf->as_Bool()->_test._test == BoolTest::ne ));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12653
  ins_cost(500);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12654
  format %{ "CMOV$cmp $dst.lo,$src.lo\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12655
            "CMOV$cmp $dst.hi,$src.hi" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12656
  opcode(0x0F,0x40);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12657
  ins_encode( enc_cmov(cmp), RegMem(dst, src), enc_cmov(cmp), RegMem_Hi(dst, src) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12658
  ins_pipe( pipe_cmov_reg_long );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12659
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12660
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12661
// Compare 2 longs and CMOVE ints.
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
 12662
instruct cmovII_reg_EQNE(cmpOp cmp, flagsReg_long_EQNE flags, rRegI dst, rRegI src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12663
  predicate(VM_Version::supports_cmov() && ( _kids[0]->_kids[0]->_leaf->as_Bool()->_test._test == BoolTest::eq || _kids[0]->_kids[0]->_leaf->as_Bool()->_test._test == BoolTest::ne ));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12664
  match(Set dst (CMoveI (Binary cmp flags) (Binary dst src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12665
  ins_cost(200);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12666
  format %{ "CMOV$cmp $dst,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12667
  opcode(0x0F,0x40);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12668
  ins_encode( enc_cmov(cmp), RegReg( dst, src ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12669
  ins_pipe( pipe_cmov_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12670
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12671
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
 12672
instruct cmovII_mem_EQNE(cmpOp cmp, flagsReg_long_EQNE flags, rRegI dst, memory src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12673
  predicate(VM_Version::supports_cmov() && ( _kids[0]->_kids[0]->_leaf->as_Bool()->_test._test == BoolTest::eq || _kids[0]->_kids[0]->_leaf->as_Bool()->_test._test == BoolTest::ne ));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12674
  match(Set dst (CMoveI (Binary cmp flags) (Binary dst (LoadI src))));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12675
  ins_cost(250);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12676
  format %{ "CMOV$cmp $dst,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12677
  opcode(0x0F,0x40);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12678
  ins_encode( enc_cmov(cmp), RegMem( dst, src ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12679
  ins_pipe( pipe_cmov_mem );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12680
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12681
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12682
// Compare 2 longs and CMOVE ints.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12683
instruct cmovPP_reg_EQNE(cmpOp cmp, flagsReg_long_EQNE flags, eRegP dst, eRegP src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12684
  predicate(VM_Version::supports_cmov() && ( _kids[0]->_kids[0]->_leaf->as_Bool()->_test._test == BoolTest::eq || _kids[0]->_kids[0]->_leaf->as_Bool()->_test._test == BoolTest::ne ));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12685
  match(Set dst (CMoveP (Binary cmp flags) (Binary dst src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12686
  ins_cost(200);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12687
  format %{ "CMOV$cmp $dst,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12688
  opcode(0x0F,0x40);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12689
  ins_encode( enc_cmov(cmp), RegReg( dst, src ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12690
  ins_pipe( pipe_cmov_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12691
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12692
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12693
// Compare 2 longs and CMOVE doubles
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 12694
instruct cmovDDPR_reg_EQNE(cmpOp cmp, flagsReg_long_EQNE flags, regDPR dst, regDPR src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12695
  predicate( UseSSE<=1 && _kids[0]->_kids[0]->_leaf->as_Bool()->_test._test == BoolTest::eq || _kids[0]->_kids[0]->_leaf->as_Bool()->_test._test == BoolTest::ne );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12696
  match(Set dst (CMoveD (Binary cmp flags) (Binary dst src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12697
  ins_cost(200);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12698
  expand %{
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 12699
    fcmovDPR_regS(cmp,flags,dst,src);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12700
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12701
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12702
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12703
// Compare 2 longs and CMOVE doubles
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 12704
instruct cmovDD_reg_EQNE(cmpOp cmp, flagsReg_long_EQNE flags, regD dst, regD src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12705
  predicate( UseSSE>=2 && _kids[0]->_kids[0]->_leaf->as_Bool()->_test._test == BoolTest::eq || _kids[0]->_kids[0]->_leaf->as_Bool()->_test._test == BoolTest::ne );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12706
  match(Set dst (CMoveD (Binary cmp flags) (Binary dst src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12707
  ins_cost(200);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12708
  expand %{
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 12709
    fcmovD_regS(cmp,flags,dst,src);
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 12710
  %}
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 12711
%}
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 12712
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 12713
instruct cmovFFPR_reg_EQNE(cmpOp cmp, flagsReg_long_EQNE flags, regFPR dst, regFPR src) %{
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 12714
  predicate( UseSSE==0 && _kids[0]->_kids[0]->_leaf->as_Bool()->_test._test == BoolTest::eq || _kids[0]->_kids[0]->_leaf->as_Bool()->_test._test == BoolTest::ne );
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 12715
  match(Set dst (CMoveF (Binary cmp flags) (Binary dst src)));
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 12716
  ins_cost(200);
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 12717
  expand %{
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 12718
    fcmovFPR_regS(cmp,flags,dst,src);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12719
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12720
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12721
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12722
instruct cmovFF_reg_EQNE(cmpOp cmp, flagsReg_long_EQNE flags, regF dst, regF src) %{
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 12723
  predicate( UseSSE>=1 && _kids[0]->_kids[0]->_leaf->as_Bool()->_test._test == BoolTest::eq || _kids[0]->_kids[0]->_leaf->as_Bool()->_test._test == BoolTest::ne );
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12724
  match(Set dst (CMoveF (Binary cmp flags) (Binary dst src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12725
  ins_cost(200);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12726
  expand %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12727
    fcmovF_regS(cmp,flags,dst,src);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12728
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12729
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12730
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12731
//======
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12732
// Manifest a CmpL result in the normal flags.  Only good for LE or GT compares.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12733
// Same as cmpL_reg_flags_LEGT except must negate src
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
 12734
instruct cmpL_zero_flags_LEGT( flagsReg_long_LEGT flags, eRegL src, immL0 zero, rRegI tmp ) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12735
  match( Set flags (CmpL src zero ));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12736
  effect( TEMP tmp );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12737
  ins_cost(300);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12738
  format %{ "XOR    $tmp,$tmp\t# Long compare for -$src < 0, use commuted test\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12739
            "CMP    $tmp,$src.lo\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12740
            "SBB    $tmp,$src.hi\n\t" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12741
  ins_encode( long_cmp_flags3(src, tmp) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12742
  ins_pipe( ialu_reg_reg_long );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12743
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12744
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12745
// Manifest a CmpL result in the normal flags.  Only good for LE or GT compares.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12746
// Same as cmpL_reg_flags_LTGE except operands swapped.  Swapping operands
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12747
// requires a commuted test to get the same result.
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
 12748
instruct cmpL_reg_flags_LEGT( flagsReg_long_LEGT flags, eRegL src1, eRegL src2, rRegI tmp ) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12749
  match( Set flags (CmpL src1 src2 ));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12750
  effect( TEMP tmp );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12751
  ins_cost(300);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12752
  format %{ "CMP    $src2.lo,$src1.lo\t! Long compare, swapped operands, use with commuted test\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12753
            "MOV    $tmp,$src2.hi\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12754
            "SBB    $tmp,$src1.hi\t! Compute flags for long compare" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12755
  ins_encode( long_cmp_flags2( src2, src1, tmp ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12756
  ins_pipe( ialu_cr_reg_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12757
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12758
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12759
// Long compares reg < zero/req OR reg >= zero/req.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12760
// Just a wrapper for a normal branch, plus the predicate test
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12761
instruct cmpL_LEGT(cmpOp_commute cmp, flagsReg_long_LEGT flags, label labl) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12762
  match(If cmp flags);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12763
  effect(USE labl);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12764
  predicate( _kids[0]->_leaf->as_Bool()->_test._test == BoolTest::gt || _kids[0]->_leaf->as_Bool()->_test._test == BoolTest::le );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12765
  ins_cost(300);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12766
  expand %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12767
    jmpCon(cmp,flags,labl);    // JGT or JLE...
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12768
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12769
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12770
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12771
// Compare 2 longs and CMOVE longs.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12772
instruct cmovLL_reg_LEGT(cmpOp_commute cmp, flagsReg_long_LEGT flags, eRegL dst, eRegL src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12773
  match(Set dst (CMoveL (Binary cmp flags) (Binary dst src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12774
  predicate(VM_Version::supports_cmov() && ( _kids[0]->_kids[0]->_leaf->as_Bool()->_test._test == BoolTest::le || _kids[0]->_kids[0]->_leaf->as_Bool()->_test._test == BoolTest::gt ));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12775
  ins_cost(400);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12776
  format %{ "CMOV$cmp $dst.lo,$src.lo\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12777
            "CMOV$cmp $dst.hi,$src.hi" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12778
  opcode(0x0F,0x40);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12779
  ins_encode( enc_cmov(cmp), RegReg_Lo2( dst, src ), enc_cmov(cmp), RegReg_Hi2( dst, src ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12780
  ins_pipe( pipe_cmov_reg_long );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12781
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12782
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12783
instruct cmovLL_mem_LEGT(cmpOp_commute cmp, flagsReg_long_LEGT flags, eRegL dst, load_long_memory src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12784
  match(Set dst (CMoveL (Binary cmp flags) (Binary dst (LoadL src))));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12785
  predicate(VM_Version::supports_cmov() && ( _kids[0]->_kids[0]->_leaf->as_Bool()->_test._test == BoolTest::le || _kids[0]->_kids[0]->_leaf->as_Bool()->_test._test == BoolTest::gt ));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12786
  ins_cost(500);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12787
  format %{ "CMOV$cmp $dst.lo,$src.lo\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12788
            "CMOV$cmp $dst.hi,$src.hi+4" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12789
  opcode(0x0F,0x40);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12790
  ins_encode( enc_cmov(cmp), RegMem(dst, src), enc_cmov(cmp), RegMem_Hi(dst, src) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12791
  ins_pipe( pipe_cmov_reg_long );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12792
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12793
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12794
// Compare 2 longs and CMOVE ints.
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
 12795
instruct cmovII_reg_LEGT(cmpOp_commute cmp, flagsReg_long_LEGT flags, rRegI dst, rRegI src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12796
  predicate(VM_Version::supports_cmov() && ( _kids[0]->_kids[0]->_leaf->as_Bool()->_test._test == BoolTest::le || _kids[0]->_kids[0]->_leaf->as_Bool()->_test._test == BoolTest::gt ));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12797
  match(Set dst (CMoveI (Binary cmp flags) (Binary dst src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12798
  ins_cost(200);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12799
  format %{ "CMOV$cmp $dst,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12800
  opcode(0x0F,0x40);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12801
  ins_encode( enc_cmov(cmp), RegReg( dst, src ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12802
  ins_pipe( pipe_cmov_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12803
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12804
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
 12805
instruct cmovII_mem_LEGT(cmpOp_commute cmp, flagsReg_long_LEGT flags, rRegI dst, memory src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12806
  predicate(VM_Version::supports_cmov() && ( _kids[0]->_kids[0]->_leaf->as_Bool()->_test._test == BoolTest::le || _kids[0]->_kids[0]->_leaf->as_Bool()->_test._test == BoolTest::gt ));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12807
  match(Set dst (CMoveI (Binary cmp flags) (Binary dst (LoadI src))));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12808
  ins_cost(250);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12809
  format %{ "CMOV$cmp $dst,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12810
  opcode(0x0F,0x40);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12811
  ins_encode( enc_cmov(cmp), RegMem( dst, src ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12812
  ins_pipe( pipe_cmov_mem );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12813
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12814
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12815
// Compare 2 longs and CMOVE ptrs.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12816
instruct cmovPP_reg_LEGT(cmpOp_commute cmp, flagsReg_long_LEGT flags, eRegP dst, eRegP src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12817
  predicate(VM_Version::supports_cmov() && ( _kids[0]->_kids[0]->_leaf->as_Bool()->_test._test == BoolTest::le || _kids[0]->_kids[0]->_leaf->as_Bool()->_test._test == BoolTest::gt ));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12818
  match(Set dst (CMoveP (Binary cmp flags) (Binary dst src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12819
  ins_cost(200);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12820
  format %{ "CMOV$cmp $dst,$src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12821
  opcode(0x0F,0x40);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12822
  ins_encode( enc_cmov(cmp), RegReg( dst, src ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12823
  ins_pipe( pipe_cmov_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12824
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12825
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12826
// Compare 2 longs and CMOVE doubles
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 12827
instruct cmovDDPR_reg_LEGT(cmpOp_commute cmp, flagsReg_long_LEGT flags, regDPR dst, regDPR src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12828
  predicate( UseSSE<=1 && _kids[0]->_kids[0]->_leaf->as_Bool()->_test._test == BoolTest::le || _kids[0]->_kids[0]->_leaf->as_Bool()->_test._test == BoolTest::gt );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12829
  match(Set dst (CMoveD (Binary cmp flags) (Binary dst src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12830
  ins_cost(200);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12831
  expand %{
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 12832
    fcmovDPR_regS(cmp,flags,dst,src);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12833
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12834
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12835
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12836
// Compare 2 longs and CMOVE doubles
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 12837
instruct cmovDD_reg_LEGT(cmpOp_commute cmp, flagsReg_long_LEGT flags, regD dst, regD src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12838
  predicate( UseSSE>=2 && _kids[0]->_kids[0]->_leaf->as_Bool()->_test._test == BoolTest::le || _kids[0]->_kids[0]->_leaf->as_Bool()->_test._test == BoolTest::gt );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12839
  match(Set dst (CMoveD (Binary cmp flags) (Binary dst src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12840
  ins_cost(200);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12841
  expand %{
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 12842
    fcmovD_regS(cmp,flags,dst,src);
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 12843
  %}
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 12844
%}
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 12845
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 12846
instruct cmovFFPR_reg_LEGT(cmpOp_commute cmp, flagsReg_long_LEGT flags, regFPR dst, regFPR src) %{
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 12847
  predicate( UseSSE==0 && _kids[0]->_kids[0]->_leaf->as_Bool()->_test._test == BoolTest::le || _kids[0]->_kids[0]->_leaf->as_Bool()->_test._test == BoolTest::gt );
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 12848
  match(Set dst (CMoveF (Binary cmp flags) (Binary dst src)));
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 12849
  ins_cost(200);
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 12850
  expand %{
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 12851
    fcmovFPR_regS(cmp,flags,dst,src);
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 12852
  %}
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 12853
%}
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 12854
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12855
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12856
instruct cmovFF_reg_LEGT(cmpOp_commute cmp, flagsReg_long_LEGT flags, regF dst, regF src) %{
11429
e894217a5d94 7121648: Use 3-operands SIMD instructions on x86 with AVX
kvn
parents: 11427
diff changeset
 12857
  predicate( UseSSE>=1 && _kids[0]->_kids[0]->_leaf->as_Bool()->_test._test == BoolTest::le || _kids[0]->_kids[0]->_leaf->as_Bool()->_test._test == BoolTest::gt );
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12858
  match(Set dst (CMoveF (Binary cmp flags) (Binary dst src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12859
  ins_cost(200);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12860
  expand %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12861
    fcmovF_regS(cmp,flags,dst,src);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12862
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12863
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12864
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12865
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12866
// ============================================================================
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12867
// Procedure Call/Return Instructions
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12868
// Call Java Static Instruction
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12869
// Note: If this code changes, the corresponding ret_addr_offset() and
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12870
//       compute_padding() functions will have to be adjusted.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12871
instruct CallStaticJavaDirect(method meth) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12872
  match(CallStaticJava);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12873
  effect(USE meth);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12874
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12875
  ins_cost(300);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12876
  format %{ "CALL,static " %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12877
  opcode(0xE8); /* E8 cd */
16624
9dbd4b210bf9 8011102: Clear AVX registers after return from JNI call
kvn
parents: 15242
diff changeset
 12878
  ins_encode( pre_call_resets,
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12879
              Java_Static_Call( meth ),
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12880
              call_epilog,
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12881
              post_call_FPU );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12882
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12883
  ins_alignment(4);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12884
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12885
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12886
// Call Java Dynamic Instruction
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12887
// Note: If this code changes, the corresponding ret_addr_offset() and
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12888
//       compute_padding() functions will have to be adjusted.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12889
instruct CallDynamicJavaDirect(method meth) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12890
  match(CallDynamicJava);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12891
  effect(USE meth);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12892
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12893
  ins_cost(300);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12894
  format %{ "MOV    EAX,(oop)-1\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12895
            "CALL,dynamic" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12896
  opcode(0xE8); /* E8 cd */
16624
9dbd4b210bf9 8011102: Clear AVX registers after return from JNI call
kvn
parents: 15242
diff changeset
 12897
  ins_encode( pre_call_resets,
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12898
              Java_Dynamic_Call( meth ),
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12899
              call_epilog,
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12900
              post_call_FPU );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12901
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12902
  ins_alignment(4);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12903
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12904
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12905
// Call Runtime Instruction
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12906
instruct CallRuntimeDirect(method meth) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12907
  match(CallRuntime );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12908
  effect(USE meth);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12909
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12910
  ins_cost(300);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12911
  format %{ "CALL,runtime " %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12912
  opcode(0xE8); /* E8 cd */
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12913
  // Use FFREEs to clear entries in float stack
16624
9dbd4b210bf9 8011102: Clear AVX registers after return from JNI call
kvn
parents: 15242
diff changeset
 12914
  ins_encode( pre_call_resets,
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12915
              FFree_Float_Stack_All,
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12916
              Java_To_Runtime( meth ),
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12917
              post_call_FPU );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12918
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12919
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12920
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12921
// Call runtime without safepoint
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12922
instruct CallLeafDirect(method meth) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12923
  match(CallLeaf);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12924
  effect(USE meth);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12925
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12926
  ins_cost(300);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12927
  format %{ "CALL_LEAF,runtime " %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12928
  opcode(0xE8); /* E8 cd */
16624
9dbd4b210bf9 8011102: Clear AVX registers after return from JNI call
kvn
parents: 15242
diff changeset
 12929
  ins_encode( pre_call_resets,
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12930
              FFree_Float_Stack_All,
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12931
              Java_To_Runtime( meth ),
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12932
              Verify_FPU_For_Leaf, post_call_FPU );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12933
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12934
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12935
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12936
instruct CallLeafNoFPDirect(method meth) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12937
  match(CallLeafNoFP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12938
  effect(USE meth);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12939
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12940
  ins_cost(300);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12941
  format %{ "CALL_LEAF_NOFP,runtime " %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12942
  opcode(0xE8); /* E8 cd */
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12943
  ins_encode(Java_To_Runtime(meth));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12944
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12945
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12946
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12947
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12948
// Return Instruction
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12949
// Remove the return address & jump to it.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12950
instruct Ret() %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12951
  match(Return);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12952
  format %{ "RET" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12953
  opcode(0xC3);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12954
  ins_encode(OpcP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12955
  ins_pipe( pipe_jmp );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12956
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12957
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12958
// Tail Call; Jump from runtime stub to Java code.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12959
// Also known as an 'interprocedural jump'.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12960
// Target of jump will eventually return to caller.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12961
// TailJump below removes the return address.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12962
instruct TailCalljmpInd(eRegP_no_EBP jump_target, eBXRegP method_oop) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12963
  match(TailCall jump_target method_oop );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12964
  ins_cost(300);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12965
  format %{ "JMP    $jump_target \t# EBX holds method oop" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12966
  opcode(0xFF, 0x4);  /* Opcode FF /4 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12967
  ins_encode( OpcP, RegOpc(jump_target) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12968
  ins_pipe( pipe_jmp );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12969
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12970
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12971
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12972
// Tail Jump; remove the return address; jump to target.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12973
// TailCall above leaves the return address around.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12974
instruct tailjmpInd(eRegP_no_EBP jump_target, eAXRegP ex_oop) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12975
  match( TailJump jump_target ex_oop );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12976
  ins_cost(300);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12977
  format %{ "POP    EDX\t# pop return address into dummy\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12978
            "JMP    $jump_target " %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12979
  opcode(0xFF, 0x4);  /* Opcode FF /4 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12980
  ins_encode( enc_pop_rdx,
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12981
              OpcP, RegOpc(jump_target) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12982
  ins_pipe( pipe_jmp );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12983
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12984
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12985
// Create exception oop: created by stack-crawling runtime code.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12986
// Created exception is now available to this handler, and is setup
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12987
// just prior to jumping to this handler.  No code emitted.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12988
instruct CreateException( eAXRegP ex_oop )
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12989
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12990
  match(Set ex_oop (CreateEx));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12991
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12992
  size(0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12993
  // use the following format syntax
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12994
  format %{ "# exception oop is in EAX; no code emitted" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12995
  ins_encode();
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12996
  ins_pipe( empty );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12997
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12998
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12999
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13000
// Rethrow exception:
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13001
// The exception oop will come in the first argument position.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13002
// Then JUMP (not call) to the rethrow stub code.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13003
instruct RethrowException()
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13004
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13005
  match(Rethrow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13006
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13007
  // use the following format syntax
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13008
  format %{ "JMP    rethrow_stub" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13009
  ins_encode(enc_rethrow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13010
  ins_pipe( pipe_jmp );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13011
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13012
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13013
// inlined locking and unlocking
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13014
23491
f690330b10b9 8031320: Use Intel RTM instructions for locks
kvn
parents: 23220
diff changeset
 13015
instruct cmpFastLockRTM(eFlagsReg cr, eRegP object, eBXRegP box, eAXRegI tmp, eDXRegI scr, rRegI cx1, rRegI cx2) %{
f690330b10b9 8031320: Use Intel RTM instructions for locks
kvn
parents: 23220
diff changeset
 13016
  predicate(Compile::current()->use_rtm());
f690330b10b9 8031320: Use Intel RTM instructions for locks
kvn
parents: 23220
diff changeset
 13017
  match(Set cr (FastLock object box));
f690330b10b9 8031320: Use Intel RTM instructions for locks
kvn
parents: 23220
diff changeset
 13018
  effect(TEMP tmp, TEMP scr, TEMP cx1, TEMP cx2, USE_KILL box);
f690330b10b9 8031320: Use Intel RTM instructions for locks
kvn
parents: 23220
diff changeset
 13019
  ins_cost(300);
f690330b10b9 8031320: Use Intel RTM instructions for locks
kvn
parents: 23220
diff changeset
 13020
  format %{ "FASTLOCK $object,$box\t! kills $box,$tmp,$scr,$cx1,$cx2" %}
f690330b10b9 8031320: Use Intel RTM instructions for locks
kvn
parents: 23220
diff changeset
 13021
  ins_encode %{
f690330b10b9 8031320: Use Intel RTM instructions for locks
kvn
parents: 23220
diff changeset
 13022
    __ fast_lock($object$$Register, $box$$Register, $tmp$$Register,
f690330b10b9 8031320: Use Intel RTM instructions for locks
kvn
parents: 23220
diff changeset
 13023
                 $scr$$Register, $cx1$$Register, $cx2$$Register,
f690330b10b9 8031320: Use Intel RTM instructions for locks
kvn
parents: 23220
diff changeset
 13024
                 _counters, _rtm_counters, _stack_rtm_counters,
f690330b10b9 8031320: Use Intel RTM instructions for locks
kvn
parents: 23220
diff changeset
 13025
                 ((Method*)(ra_->C->method()->constant_encoding()))->method_data(),
f690330b10b9 8031320: Use Intel RTM instructions for locks
kvn
parents: 23220
diff changeset
 13026
                 true, ra_->C->profile_rtm());
f690330b10b9 8031320: Use Intel RTM instructions for locks
kvn
parents: 23220
diff changeset
 13027
  %}
f690330b10b9 8031320: Use Intel RTM instructions for locks
kvn
parents: 23220
diff changeset
 13028
  ins_pipe(pipe_slow);
f690330b10b9 8031320: Use Intel RTM instructions for locks
kvn
parents: 23220
diff changeset
 13029
%}
f690330b10b9 8031320: Use Intel RTM instructions for locks
kvn
parents: 23220
diff changeset
 13030
22910
88c3369b5967 8033805: Move Fast_Lock/Fast_Unlock code from .ad files to macroassembler
kvn
parents: 22873
diff changeset
 13031
instruct cmpFastLock(eFlagsReg cr, eRegP object, eBXRegP box, eAXRegI tmp, eRegP scr) %{
23491
f690330b10b9 8031320: Use Intel RTM instructions for locks
kvn
parents: 23220
diff changeset
 13032
  predicate(!Compile::current()->use_rtm());
22910
88c3369b5967 8033805: Move Fast_Lock/Fast_Unlock code from .ad files to macroassembler
kvn
parents: 22873
diff changeset
 13033
  match(Set cr (FastLock object box));
88c3369b5967 8033805: Move Fast_Lock/Fast_Unlock code from .ad files to macroassembler
kvn
parents: 22873
diff changeset
 13034
  effect(TEMP tmp, TEMP scr, USE_KILL box);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13035
  ins_cost(300);
11445
3c768dca60f5 7125896: Eliminate nested locks
kvn
parents: 11431
diff changeset
 13036
  format %{ "FASTLOCK $object,$box\t! kills $box,$tmp,$scr" %}
22910
88c3369b5967 8033805: Move Fast_Lock/Fast_Unlock code from .ad files to macroassembler
kvn
parents: 22873
diff changeset
 13037
  ins_encode %{
23491
f690330b10b9 8031320: Use Intel RTM instructions for locks
kvn
parents: 23220
diff changeset
 13038
    __ fast_lock($object$$Register, $box$$Register, $tmp$$Register,
f690330b10b9 8031320: Use Intel RTM instructions for locks
kvn
parents: 23220
diff changeset
 13039
                 $scr$$Register, noreg, noreg, _counters, NULL, NULL, NULL, false, false);
22910
88c3369b5967 8033805: Move Fast_Lock/Fast_Unlock code from .ad files to macroassembler
kvn
parents: 22873
diff changeset
 13040
  %}
88c3369b5967 8033805: Move Fast_Lock/Fast_Unlock code from .ad files to macroassembler
kvn
parents: 22873
diff changeset
 13041
  ins_pipe(pipe_slow);
88c3369b5967 8033805: Move Fast_Lock/Fast_Unlock code from .ad files to macroassembler
kvn
parents: 22873
diff changeset
 13042
%}
88c3369b5967 8033805: Move Fast_Lock/Fast_Unlock code from .ad files to macroassembler
kvn
parents: 22873
diff changeset
 13043
88c3369b5967 8033805: Move Fast_Lock/Fast_Unlock code from .ad files to macroassembler
kvn
parents: 22873
diff changeset
 13044
instruct cmpFastUnlock(eFlagsReg cr, eRegP object, eAXRegP box, eRegP tmp ) %{
88c3369b5967 8033805: Move Fast_Lock/Fast_Unlock code from .ad files to macroassembler
kvn
parents: 22873
diff changeset
 13045
  match(Set cr (FastUnlock object box));
88c3369b5967 8033805: Move Fast_Lock/Fast_Unlock code from .ad files to macroassembler
kvn
parents: 22873
diff changeset
 13046
  effect(TEMP tmp, USE_KILL box);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13047
  ins_cost(300);
11445
3c768dca60f5 7125896: Eliminate nested locks
kvn
parents: 11431
diff changeset
 13048
  format %{ "FASTUNLOCK $object,$box\t! kills $box,$tmp" %}
22910
88c3369b5967 8033805: Move Fast_Lock/Fast_Unlock code from .ad files to macroassembler
kvn
parents: 22873
diff changeset
 13049
  ins_encode %{
23491
f690330b10b9 8031320: Use Intel RTM instructions for locks
kvn
parents: 23220
diff changeset
 13050
    __ fast_unlock($object$$Register, $box$$Register, $tmp$$Register, ra_->C->use_rtm());
22910
88c3369b5967 8033805: Move Fast_Lock/Fast_Unlock code from .ad files to macroassembler
kvn
parents: 22873
diff changeset
 13051
  %}
88c3369b5967 8033805: Move Fast_Lock/Fast_Unlock code from .ad files to macroassembler
kvn
parents: 22873
diff changeset
 13052
  ins_pipe(pipe_slow);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13053
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13054
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13055
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13056
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13057
// ============================================================================
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13058
// Safepoint Instruction
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13059
instruct safePoint_poll(eFlagsReg cr) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13060
  match(SafePoint);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13061
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13062
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13063
  // TODO-FIXME: we currently poll at offset 0 of the safepoint polling page.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13064
  // On SPARC that might be acceptable as we can generate the address with
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13065
  // just a sethi, saving an or.  By polling at offset 0 we can end up
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13066
  // putting additional pressure on the index-0 in the D$.  Because of
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13067
  // alignment (just like the situation at hand) the lower indices tend
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13068
  // to see more traffic.  It'd be better to change the polling address
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13069
  // to offset 0 of the last $line in the polling page.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13070
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13071
  format %{ "TSTL   #polladdr,EAX\t! Safepoint: poll for GC" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13072
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13073
  size(6) ;
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13074
  ins_encode( Safepoint_Poll() );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13075
  ins_pipe( ialu_reg_mem );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13076
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13077
11794
72249bf6ab83 7145346: VerifyStackAtCalls is broken
kvn
parents: 11791
diff changeset
 13078
72249bf6ab83 7145346: VerifyStackAtCalls is broken
kvn
parents: 11791
diff changeset
 13079
// ============================================================================
72249bf6ab83 7145346: VerifyStackAtCalls is broken
kvn
parents: 11791
diff changeset
 13080
// This name is KNOWN by the ADLC and cannot be changed.
72249bf6ab83 7145346: VerifyStackAtCalls is broken
kvn
parents: 11791
diff changeset
 13081
// The ADLC forces a 'TypeRawPtr::BOTTOM' output type
72249bf6ab83 7145346: VerifyStackAtCalls is broken
kvn
parents: 11791
diff changeset
 13082
// for this guy.
72249bf6ab83 7145346: VerifyStackAtCalls is broken
kvn
parents: 11791
diff changeset
 13083
instruct tlsLoadP(eRegP dst, eFlagsReg cr) %{
72249bf6ab83 7145346: VerifyStackAtCalls is broken
kvn
parents: 11791
diff changeset
 13084
  match(Set dst (ThreadLocal));
72249bf6ab83 7145346: VerifyStackAtCalls is broken
kvn
parents: 11791
diff changeset
 13085
  effect(DEF dst, KILL cr);
72249bf6ab83 7145346: VerifyStackAtCalls is broken
kvn
parents: 11791
diff changeset
 13086
72249bf6ab83 7145346: VerifyStackAtCalls is broken
kvn
parents: 11791
diff changeset
 13087
  format %{ "MOV    $dst, Thread::current()" %}
72249bf6ab83 7145346: VerifyStackAtCalls is broken
kvn
parents: 11791
diff changeset
 13088
  ins_encode %{
72249bf6ab83 7145346: VerifyStackAtCalls is broken
kvn
parents: 11791
diff changeset
 13089
    Register dstReg = as_Register($dst$$reg);
72249bf6ab83 7145346: VerifyStackAtCalls is broken
kvn
parents: 11791
diff changeset
 13090
    __ get_thread(dstReg);
72249bf6ab83 7145346: VerifyStackAtCalls is broken
kvn
parents: 11791
diff changeset
 13091
  %}
72249bf6ab83 7145346: VerifyStackAtCalls is broken
kvn
parents: 11791
diff changeset
 13092
  ins_pipe( ialu_reg_fat );
72249bf6ab83 7145346: VerifyStackAtCalls is broken
kvn
parents: 11791
diff changeset
 13093
%}
72249bf6ab83 7145346: VerifyStackAtCalls is broken
kvn
parents: 11791
diff changeset
 13094
72249bf6ab83 7145346: VerifyStackAtCalls is broken
kvn
parents: 11791
diff changeset
 13095
72249bf6ab83 7145346: VerifyStackAtCalls is broken
kvn
parents: 11791
diff changeset
 13096
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13097
//----------PEEPHOLE RULES-----------------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13098
// These must follow all instruction definitions as they use the names
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13099
// defined in the instructions definitions.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13100
//
2131
98f9cef66a34 6810672: Comment typos
twisti
parents: 2034
diff changeset
 13101
// peepmatch ( root_instr_name [preceding_instruction]* );
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13102
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13103
// peepconstraint %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13104
// (instruction_number.operand_name relational_op instruction_number.operand_name
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13105
//  [, ...] );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13106
// // instruction numbers are zero-based using left to right order in peepmatch
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13107
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13108
// peepreplace ( instr_name  ( [instruction_number.operand_name]* ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13109
// // provide an instruction_number.operand_name for each operand that appears
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13110
// // in the replacement instruction's match rule
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13111
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13112
// ---------VM FLAGS---------------------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13113
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13114
// All peephole optimizations can be turned off using -XX:-OptoPeephole
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13115
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13116
// Each peephole rule is given an identifying number starting with zero and
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13117
// increasing by one in the order seen by the parser.  An individual peephole
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13118
// can be enabled, and all others disabled, by using -XX:OptoPeepholeAt=#
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13119
// on the command-line.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13120
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13121
// ---------CURRENT LIMITATIONS----------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13122
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13123
// Only match adjacent instructions in same basic block
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13124
// Only equality constraints
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13125
// Only constraints between operands, not (0.dest_reg == EAX_enc)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13126
// Only one replacement instruction
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13127
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13128
// ---------EXAMPLE----------------------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13129
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13130
// // pertinent parts of existing instructions in architecture description
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
 13131
// instruct movI(rRegI dst, rRegI src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13132
//   match(Set dst (CopyI src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13133
// %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13134
//
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
 13135
// instruct incI_eReg(rRegI dst, immI1 src, eFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13136
//   match(Set dst (AddI dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13137
//   effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13138
// %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13139
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13140
// // Change (inc mov) to lea
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13141
// peephole %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13142
//   // increment preceeded by register-register move
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13143
//   peepmatch ( incI_eReg movI );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13144
//   // require that the destination register of the increment
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13145
//   // match the destination register of the move
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13146
//   peepconstraint ( 0.dst == 1.dst );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13147
//   // construct a replacement instruction that sets
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13148
//   // the destination to ( move's source register + one )
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13149
//   peepreplace ( leaI_eReg_immI( 0.dst 1.src 0.src ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13150
// %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13151
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13152
// Implementation no longer uses movX instructions since
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13153
// machine-independent system no longer uses CopyX nodes.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13154
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13155
// peephole %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13156
//   peepmatch ( incI_eReg movI );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13157
//   peepconstraint ( 0.dst == 1.dst );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13158
//   peepreplace ( leaI_eReg_immI( 0.dst 1.src 0.src ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13159
// %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13160
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13161
// peephole %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13162
//   peepmatch ( decI_eReg movI );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13163
//   peepconstraint ( 0.dst == 1.dst );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13164
//   peepreplace ( leaI_eReg_immI( 0.dst 1.src 0.src ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13165
// %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13166
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13167
// peephole %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13168
//   peepmatch ( addI_eReg_imm movI );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13169
//   peepconstraint ( 0.dst == 1.dst );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13170
//   peepreplace ( leaI_eReg_immI( 0.dst 1.src 0.src ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13171
// %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13172
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13173
// peephole %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13174
//   peepmatch ( addP_eReg_imm movP );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13175
//   peepconstraint ( 0.dst == 1.dst );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13176
//   peepreplace ( leaP_eReg_immI( 0.dst 1.src 0.src ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13177
// %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13178
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13179
// // Change load of spilled value to only a spill
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
 13180
// instruct storeI(memory mem, rRegI src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13181
//   match(Set mem (StoreI mem src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13182
// %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13183
//
13104
657b387034fb 7119644: Increase superword's vector size up to 256 bits
kvn
parents: 12957
diff changeset
 13184
// instruct loadI(rRegI dst, memory mem) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13185
//   match(Set dst (LoadI mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13186
// %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13187
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13188
peephole %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13189
  peepmatch ( loadI storeI );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13190
  peepconstraint ( 1.src == 0.dst, 1.mem == 0.mem );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13191
  peepreplace ( storeI( 1.mem 1.mem 1.src ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13192
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13193
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13194
//----------SMARTSPILL RULES---------------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13195
// These must follow all instruction definitions as they use the names
489c9b5090e2 Initial load
duke
parents:
diff changeset
 13196
// defined in the instructions definitions.