hotspot/src/cpu/x86/vm/x86_64.ad
author johnc
Tue, 27 Apr 2010 18:13:47 -0700
changeset 5401 30bda607cb67
parent 5025 05adc9b8f96a
child 5352 cee8f7acb7bc
permissions -rw-r--r--
6946056: assert((intptr_t) sp()<=(intptr_t) result,"result must>=than stack pointer"), frame_x86.cpp:295 Summary: frame::interpreter_frame_monitor_end() will spuriously assert for a frame that spans 0x80000000. Cast values to intptr_t* (rather than intptr_t) so that an unsigned pointer compare is performed. Reviewed-by: never, jcoomes, pbk
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
     1
//
2150
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
     2
// Copyright 2003-2009 Sun Microsystems, Inc.  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
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
    19
// Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
489c9b5090e2 Initial load
duke
parents:
diff changeset
    20
// CA 95054 USA or visit www.sun.com if you need additional information or
489c9b5090e2 Initial load
duke
parents:
diff changeset
    21
// have any questions.
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
// AMD64 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
// R8-R15 must be encoded with REX.  (RSP, RBP, RSI, RDI need REX when
489c9b5090e2 Initial load
duke
parents:
diff changeset
    64
// used as byte registers)
489c9b5090e2 Initial load
duke
parents:
diff changeset
    65
489c9b5090e2 Initial load
duke
parents:
diff changeset
    66
// Previously set RBX, RSI, and RDI as save-on-entry for java code
489c9b5090e2 Initial load
duke
parents:
diff changeset
    67
// Turn off SOE in java-code due to frequent use of uncommon-traps.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    68
// Now that allocator is better, turn on RSI and RDI as SOE registers.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    69
489c9b5090e2 Initial load
duke
parents:
diff changeset
    70
reg_def RAX  (SOC, SOC, Op_RegI,  0, rax->as_VMReg());
489c9b5090e2 Initial load
duke
parents:
diff changeset
    71
reg_def RAX_H(SOC, SOC, Op_RegI,  0, rax->as_VMReg()->next());
489c9b5090e2 Initial load
duke
parents:
diff changeset
    72
489c9b5090e2 Initial load
duke
parents:
diff changeset
    73
reg_def RCX  (SOC, SOC, Op_RegI,  1, rcx->as_VMReg());
489c9b5090e2 Initial load
duke
parents:
diff changeset
    74
reg_def RCX_H(SOC, SOC, Op_RegI,  1, rcx->as_VMReg()->next());
489c9b5090e2 Initial load
duke
parents:
diff changeset
    75
489c9b5090e2 Initial load
duke
parents:
diff changeset
    76
reg_def RDX  (SOC, SOC, Op_RegI,  2, rdx->as_VMReg());
489c9b5090e2 Initial load
duke
parents:
diff changeset
    77
reg_def RDX_H(SOC, SOC, Op_RegI,  2, rdx->as_VMReg()->next());
489c9b5090e2 Initial load
duke
parents:
diff changeset
    78
489c9b5090e2 Initial load
duke
parents:
diff changeset
    79
reg_def RBX  (SOC, SOE, Op_RegI,  3, rbx->as_VMReg());
489c9b5090e2 Initial load
duke
parents:
diff changeset
    80
reg_def RBX_H(SOC, SOE, Op_RegI,  3, rbx->as_VMReg()->next());
489c9b5090e2 Initial load
duke
parents:
diff changeset
    81
489c9b5090e2 Initial load
duke
parents:
diff changeset
    82
reg_def RSP  (NS,  NS,  Op_RegI,  4, rsp->as_VMReg());
489c9b5090e2 Initial load
duke
parents:
diff changeset
    83
reg_def RSP_H(NS,  NS,  Op_RegI,  4, rsp->as_VMReg()->next());
489c9b5090e2 Initial load
duke
parents:
diff changeset
    84
489c9b5090e2 Initial load
duke
parents:
diff changeset
    85
// now that adapter frames are gone RBP is always saved and restored by the prolog/epilog code
489c9b5090e2 Initial load
duke
parents:
diff changeset
    86
reg_def RBP  (NS, SOE, Op_RegI,  5, rbp->as_VMReg());
489c9b5090e2 Initial load
duke
parents:
diff changeset
    87
reg_def RBP_H(NS, SOE, Op_RegI,  5, rbp->as_VMReg()->next());
489c9b5090e2 Initial load
duke
parents:
diff changeset
    88
489c9b5090e2 Initial load
duke
parents:
diff changeset
    89
#ifdef _WIN64
489c9b5090e2 Initial load
duke
parents:
diff changeset
    90
489c9b5090e2 Initial load
duke
parents:
diff changeset
    91
reg_def RSI  (SOC, SOE, Op_RegI,  6, rsi->as_VMReg());
489c9b5090e2 Initial load
duke
parents:
diff changeset
    92
reg_def RSI_H(SOC, SOE, Op_RegI,  6, rsi->as_VMReg()->next());
489c9b5090e2 Initial load
duke
parents:
diff changeset
    93
489c9b5090e2 Initial load
duke
parents:
diff changeset
    94
reg_def RDI  (SOC, SOE, Op_RegI,  7, rdi->as_VMReg());
489c9b5090e2 Initial load
duke
parents:
diff changeset
    95
reg_def RDI_H(SOC, SOE, Op_RegI,  7, rdi->as_VMReg()->next());
489c9b5090e2 Initial load
duke
parents:
diff changeset
    96
489c9b5090e2 Initial load
duke
parents:
diff changeset
    97
#else
489c9b5090e2 Initial load
duke
parents:
diff changeset
    98
489c9b5090e2 Initial load
duke
parents:
diff changeset
    99
reg_def RSI  (SOC, SOC, Op_RegI,  6, rsi->as_VMReg());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   100
reg_def RSI_H(SOC, SOC, Op_RegI,  6, rsi->as_VMReg()->next());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   101
489c9b5090e2 Initial load
duke
parents:
diff changeset
   102
reg_def RDI  (SOC, SOC, Op_RegI,  7, rdi->as_VMReg());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   103
reg_def RDI_H(SOC, SOC, Op_RegI,  7, rdi->as_VMReg()->next());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   104
489c9b5090e2 Initial load
duke
parents:
diff changeset
   105
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
   106
489c9b5090e2 Initial load
duke
parents:
diff changeset
   107
reg_def R8   (SOC, SOC, Op_RegI,  8, r8->as_VMReg());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   108
reg_def R8_H (SOC, SOC, Op_RegI,  8, r8->as_VMReg()->next());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   109
489c9b5090e2 Initial load
duke
parents:
diff changeset
   110
reg_def R9   (SOC, SOC, Op_RegI,  9, r9->as_VMReg());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   111
reg_def R9_H (SOC, SOC, Op_RegI,  9, r9->as_VMReg()->next());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   112
489c9b5090e2 Initial load
duke
parents:
diff changeset
   113
reg_def R10  (SOC, SOC, Op_RegI, 10, r10->as_VMReg());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   114
reg_def R10_H(SOC, SOC, Op_RegI, 10, r10->as_VMReg()->next());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   115
489c9b5090e2 Initial load
duke
parents:
diff changeset
   116
reg_def R11  (SOC, SOC, Op_RegI, 11, r11->as_VMReg());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   117
reg_def R11_H(SOC, SOC, Op_RegI, 11, r11->as_VMReg()->next());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   118
489c9b5090e2 Initial load
duke
parents:
diff changeset
   119
reg_def R12  (SOC, SOE, Op_RegI, 12, r12->as_VMReg());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   120
reg_def R12_H(SOC, SOE, Op_RegI, 12, r12->as_VMReg()->next());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   121
489c9b5090e2 Initial load
duke
parents:
diff changeset
   122
reg_def R13  (SOC, SOE, Op_RegI, 13, r13->as_VMReg());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   123
reg_def R13_H(SOC, SOE, Op_RegI, 13, r13->as_VMReg()->next());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   124
489c9b5090e2 Initial load
duke
parents:
diff changeset
   125
reg_def R14  (SOC, SOE, Op_RegI, 14, r14->as_VMReg());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   126
reg_def R14_H(SOC, SOE, Op_RegI, 14, r14->as_VMReg()->next());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   127
489c9b5090e2 Initial load
duke
parents:
diff changeset
   128
reg_def R15  (SOC, SOE, Op_RegI, 15, r15->as_VMReg());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   129
reg_def R15_H(SOC, SOE, Op_RegI, 15, r15->as_VMReg()->next());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   130
489c9b5090e2 Initial load
duke
parents:
diff changeset
   131
489c9b5090e2 Initial load
duke
parents:
diff changeset
   132
// Floating Point Registers
489c9b5090e2 Initial load
duke
parents:
diff changeset
   133
489c9b5090e2 Initial load
duke
parents:
diff changeset
   134
// XMM registers.  128-bit registers or 4 words each, labeled (a)-d.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   135
// Word a in each register holds a Float, words ab hold a Double.  We
489c9b5090e2 Initial load
duke
parents:
diff changeset
   136
// currently do not use the SIMD capabilities, so registers cd are
489c9b5090e2 Initial load
duke
parents:
diff changeset
   137
// unused at the moment.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   138
// XMM8-XMM15 must be encoded with REX.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   139
// Linux ABI:   No register preserved across function calls
489c9b5090e2 Initial load
duke
parents:
diff changeset
   140
//              XMM0-XMM7 might hold parameters
489c9b5090e2 Initial load
duke
parents:
diff changeset
   141
// Windows ABI: XMM6-XMM15 preserved across function calls
489c9b5090e2 Initial load
duke
parents:
diff changeset
   142
//              XMM0-XMM3 might hold parameters
489c9b5090e2 Initial load
duke
parents:
diff changeset
   143
489c9b5090e2 Initial load
duke
parents:
diff changeset
   144
reg_def XMM0   (SOC, SOC, Op_RegF,  0, xmm0->as_VMReg());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   145
reg_def XMM0_H (SOC, SOC, Op_RegF,  0, xmm0->as_VMReg()->next());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   146
489c9b5090e2 Initial load
duke
parents:
diff changeset
   147
reg_def XMM1   (SOC, SOC, Op_RegF,  1, xmm1->as_VMReg());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   148
reg_def XMM1_H (SOC, SOC, Op_RegF,  1, xmm1->as_VMReg()->next());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   149
489c9b5090e2 Initial load
duke
parents:
diff changeset
   150
reg_def XMM2   (SOC, SOC, Op_RegF,  2, xmm2->as_VMReg());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   151
reg_def XMM2_H (SOC, SOC, Op_RegF,  2, xmm2->as_VMReg()->next());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   152
489c9b5090e2 Initial load
duke
parents:
diff changeset
   153
reg_def XMM3   (SOC, SOC, Op_RegF,  3, xmm3->as_VMReg());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   154
reg_def XMM3_H (SOC, SOC, Op_RegF,  3, xmm3->as_VMReg()->next());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   155
489c9b5090e2 Initial load
duke
parents:
diff changeset
   156
reg_def XMM4   (SOC, SOC, Op_RegF,  4, xmm4->as_VMReg());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   157
reg_def XMM4_H (SOC, SOC, Op_RegF,  4, xmm4->as_VMReg()->next());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   158
489c9b5090e2 Initial load
duke
parents:
diff changeset
   159
reg_def XMM5   (SOC, SOC, Op_RegF,  5, xmm5->as_VMReg());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   160
reg_def XMM5_H (SOC, SOC, Op_RegF,  5, xmm5->as_VMReg()->next());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   161
489c9b5090e2 Initial load
duke
parents:
diff changeset
   162
#ifdef _WIN64
489c9b5090e2 Initial load
duke
parents:
diff changeset
   163
489c9b5090e2 Initial load
duke
parents:
diff changeset
   164
reg_def XMM6   (SOC, SOE, Op_RegF,  6, xmm6->as_VMReg());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   165
reg_def XMM6_H (SOC, SOE, Op_RegF,  6, xmm6->as_VMReg()->next());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   166
489c9b5090e2 Initial load
duke
parents:
diff changeset
   167
reg_def XMM7   (SOC, SOE, Op_RegF,  7, xmm7->as_VMReg());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   168
reg_def XMM7_H (SOC, SOE, Op_RegF,  7, xmm7->as_VMReg()->next());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   169
489c9b5090e2 Initial load
duke
parents:
diff changeset
   170
reg_def XMM8   (SOC, SOE, Op_RegF,  8, xmm8->as_VMReg());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   171
reg_def XMM8_H (SOC, SOE, Op_RegF,  8, xmm8->as_VMReg()->next());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   172
489c9b5090e2 Initial load
duke
parents:
diff changeset
   173
reg_def XMM9   (SOC, SOE, Op_RegF,  9, xmm9->as_VMReg());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   174
reg_def XMM9_H (SOC, SOE, Op_RegF,  9, xmm9->as_VMReg()->next());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   175
489c9b5090e2 Initial load
duke
parents:
diff changeset
   176
reg_def XMM10  (SOC, SOE, Op_RegF, 10, xmm10->as_VMReg());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   177
reg_def XMM10_H(SOC, SOE, Op_RegF, 10, xmm10->as_VMReg()->next());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   178
489c9b5090e2 Initial load
duke
parents:
diff changeset
   179
reg_def XMM11  (SOC, SOE, Op_RegF, 11, xmm11->as_VMReg());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   180
reg_def XMM11_H(SOC, SOE, Op_RegF, 11, xmm11->as_VMReg()->next());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   181
489c9b5090e2 Initial load
duke
parents:
diff changeset
   182
reg_def XMM12  (SOC, SOE, Op_RegF, 12, xmm12->as_VMReg());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   183
reg_def XMM12_H(SOC, SOE, Op_RegF, 12, xmm12->as_VMReg()->next());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   184
489c9b5090e2 Initial load
duke
parents:
diff changeset
   185
reg_def XMM13  (SOC, SOE, Op_RegF, 13, xmm13->as_VMReg());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   186
reg_def XMM13_H(SOC, SOE, Op_RegF, 13, xmm13->as_VMReg()->next());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   187
489c9b5090e2 Initial load
duke
parents:
diff changeset
   188
reg_def XMM14  (SOC, SOE, Op_RegF, 14, xmm14->as_VMReg());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   189
reg_def XMM14_H(SOC, SOE, Op_RegF, 14, xmm14->as_VMReg()->next());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   190
489c9b5090e2 Initial load
duke
parents:
diff changeset
   191
reg_def XMM15  (SOC, SOE, Op_RegF, 15, xmm15->as_VMReg());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   192
reg_def XMM15_H(SOC, SOE, Op_RegF, 15, xmm15->as_VMReg()->next());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   193
489c9b5090e2 Initial load
duke
parents:
diff changeset
   194
#else
489c9b5090e2 Initial load
duke
parents:
diff changeset
   195
489c9b5090e2 Initial load
duke
parents:
diff changeset
   196
reg_def XMM6   (SOC, SOC, Op_RegF,  6, xmm6->as_VMReg());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   197
reg_def XMM6_H (SOC, SOC, Op_RegF,  6, xmm6->as_VMReg()->next());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   198
489c9b5090e2 Initial load
duke
parents:
diff changeset
   199
reg_def XMM7   (SOC, SOC, Op_RegF,  7, xmm7->as_VMReg());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   200
reg_def XMM7_H (SOC, SOC, Op_RegF,  7, xmm7->as_VMReg()->next());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   201
489c9b5090e2 Initial load
duke
parents:
diff changeset
   202
reg_def XMM8   (SOC, SOC, Op_RegF,  8, xmm8->as_VMReg());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   203
reg_def XMM8_H (SOC, SOC, Op_RegF,  8, xmm8->as_VMReg()->next());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   204
489c9b5090e2 Initial load
duke
parents:
diff changeset
   205
reg_def XMM9   (SOC, SOC, Op_RegF,  9, xmm9->as_VMReg());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   206
reg_def XMM9_H (SOC, SOC, Op_RegF,  9, xmm9->as_VMReg()->next());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   207
489c9b5090e2 Initial load
duke
parents:
diff changeset
   208
reg_def XMM10  (SOC, SOC, Op_RegF, 10, xmm10->as_VMReg());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   209
reg_def XMM10_H(SOC, SOC, Op_RegF, 10, xmm10->as_VMReg()->next());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   210
489c9b5090e2 Initial load
duke
parents:
diff changeset
   211
reg_def XMM11  (SOC, SOC, Op_RegF, 11, xmm11->as_VMReg());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   212
reg_def XMM11_H(SOC, SOC, Op_RegF, 11, xmm11->as_VMReg()->next());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   213
489c9b5090e2 Initial load
duke
parents:
diff changeset
   214
reg_def XMM12  (SOC, SOC, Op_RegF, 12, xmm12->as_VMReg());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   215
reg_def XMM12_H(SOC, SOC, Op_RegF, 12, xmm12->as_VMReg()->next());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   216
489c9b5090e2 Initial load
duke
parents:
diff changeset
   217
reg_def XMM13  (SOC, SOC, Op_RegF, 13, xmm13->as_VMReg());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   218
reg_def XMM13_H(SOC, SOC, Op_RegF, 13, xmm13->as_VMReg()->next());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   219
489c9b5090e2 Initial load
duke
parents:
diff changeset
   220
reg_def XMM14  (SOC, SOC, Op_RegF, 14, xmm14->as_VMReg());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   221
reg_def XMM14_H(SOC, SOC, Op_RegF, 14, xmm14->as_VMReg()->next());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   222
489c9b5090e2 Initial load
duke
parents:
diff changeset
   223
reg_def XMM15  (SOC, SOC, Op_RegF, 15, xmm15->as_VMReg());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   224
reg_def XMM15_H(SOC, SOC, Op_RegF, 15, xmm15->as_VMReg()->next());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   225
489c9b5090e2 Initial load
duke
parents:
diff changeset
   226
#endif // _WIN64
489c9b5090e2 Initial load
duke
parents:
diff changeset
   227
489c9b5090e2 Initial load
duke
parents:
diff changeset
   228
reg_def RFLAGS(SOC, SOC, 0, 16, VMRegImpl::Bad());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   229
489c9b5090e2 Initial load
duke
parents:
diff changeset
   230
// Specify priority of register selection within phases of register
489c9b5090e2 Initial load
duke
parents:
diff changeset
   231
// allocation.  Highest priority is first.  A useful heuristic is to
489c9b5090e2 Initial load
duke
parents:
diff changeset
   232
// give registers a low priority when they are required by machine
489c9b5090e2 Initial load
duke
parents:
diff changeset
   233
// instructions, like EAX and EDX on I486, and choose no-save registers
489c9b5090e2 Initial load
duke
parents:
diff changeset
   234
// before save-on-call, & save-on-call before save-on-entry.  Registers
489c9b5090e2 Initial load
duke
parents:
diff changeset
   235
// which participate in fixed calling sequences should come last.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   236
// Registers which are used as pairs must fall on an even boundary.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   237
489c9b5090e2 Initial load
duke
parents:
diff changeset
   238
alloc_class chunk0(R10,         R10_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   239
                   R11,         R11_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   240
                   R8,          R8_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   241
                   R9,          R9_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   242
                   R12,         R12_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   243
                   RCX,         RCX_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   244
                   RBX,         RBX_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   245
                   RDI,         RDI_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   246
                   RDX,         RDX_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   247
                   RSI,         RSI_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   248
                   RAX,         RAX_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   249
                   RBP,         RBP_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   250
                   R13,         R13_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   251
                   R14,         R14_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   252
                   R15,         R15_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   253
                   RSP,         RSP_H);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   254
489c9b5090e2 Initial load
duke
parents:
diff changeset
   255
// XXX probably use 8-15 first on Linux
489c9b5090e2 Initial load
duke
parents:
diff changeset
   256
alloc_class chunk1(XMM0,  XMM0_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   257
                   XMM1,  XMM1_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   258
                   XMM2,  XMM2_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   259
                   XMM3,  XMM3_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   260
                   XMM4,  XMM4_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   261
                   XMM5,  XMM5_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   262
                   XMM6,  XMM6_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   263
                   XMM7,  XMM7_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   264
                   XMM8,  XMM8_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   265
                   XMM9,  XMM9_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   266
                   XMM10, XMM10_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   267
                   XMM11, XMM11_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   268
                   XMM12, XMM12_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   269
                   XMM13, XMM13_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   270
                   XMM14, XMM14_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   271
                   XMM15, XMM15_H);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   272
489c9b5090e2 Initial load
duke
parents:
diff changeset
   273
alloc_class chunk2(RFLAGS);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   274
489c9b5090e2 Initial load
duke
parents:
diff changeset
   275
489c9b5090e2 Initial load
duke
parents:
diff changeset
   276
//----------Architecture Description Register Classes--------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
   277
// Several register classes are automatically defined based upon information in
489c9b5090e2 Initial load
duke
parents:
diff changeset
   278
// this architecture description.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   279
// 1) reg_class inline_cache_reg           ( /* as def'd in frame section */ )
489c9b5090e2 Initial load
duke
parents:
diff changeset
   280
// 2) reg_class compiler_method_oop_reg    ( /* as def'd in frame section */ )
489c9b5090e2 Initial load
duke
parents:
diff changeset
   281
// 2) reg_class interpreter_method_oop_reg ( /* as def'd in frame section */ )
489c9b5090e2 Initial load
duke
parents:
diff changeset
   282
// 3) reg_class stack_slots( /* one chunk of stack-based "registers" */ )
489c9b5090e2 Initial load
duke
parents:
diff changeset
   283
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
   284
489c9b5090e2 Initial load
duke
parents:
diff changeset
   285
// Class for all pointer registers (including RSP)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   286
reg_class any_reg(RAX, RAX_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   287
                  RDX, RDX_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   288
                  RBP, RBP_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   289
                  RDI, RDI_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   290
                  RSI, RSI_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   291
                  RCX, RCX_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   292
                  RBX, RBX_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   293
                  RSP, RSP_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   294
                  R8,  R8_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   295
                  R9,  R9_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   296
                  R10, R10_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   297
                  R11, R11_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   298
                  R12, R12_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   299
                  R13, R13_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   300
                  R14, R14_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   301
                  R15, R15_H);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   302
489c9b5090e2 Initial load
duke
parents:
diff changeset
   303
// Class for all pointer registers except RSP
489c9b5090e2 Initial load
duke
parents:
diff changeset
   304
reg_class ptr_reg(RAX, RAX_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   305
                  RDX, RDX_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   306
                  RBP, RBP_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   307
                  RDI, RDI_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   308
                  RSI, RSI_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   309
                  RCX, RCX_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   310
                  RBX, RBX_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   311
                  R8,  R8_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   312
                  R9,  R9_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   313
                  R10, R10_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   314
                  R11, R11_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   315
                  R13, R13_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   316
                  R14, R14_H);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   317
489c9b5090e2 Initial load
duke
parents:
diff changeset
   318
// Class for all pointer registers except RAX and RSP
489c9b5090e2 Initial load
duke
parents:
diff changeset
   319
reg_class ptr_no_rax_reg(RDX, RDX_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   320
                         RBP, RBP_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   321
                         RDI, RDI_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   322
                         RSI, RSI_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   323
                         RCX, RCX_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   324
                         RBX, RBX_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   325
                         R8,  R8_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   326
                         R9,  R9_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   327
                         R10, R10_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   328
                         R11, R11_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   329
                         R13, R13_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   330
                         R14, R14_H);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   331
489c9b5090e2 Initial load
duke
parents:
diff changeset
   332
reg_class ptr_no_rbp_reg(RDX, RDX_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   333
                         RAX, RAX_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   334
                         RDI, RDI_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   335
                         RSI, RSI_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   336
                         RCX, RCX_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   337
                         RBX, RBX_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   338
                         R8,  R8_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   339
                         R9,  R9_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   340
                         R10, R10_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   341
                         R11, R11_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   342
                         R13, R13_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   343
                         R14, R14_H);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   344
489c9b5090e2 Initial load
duke
parents:
diff changeset
   345
// Class for all pointer registers except RAX, RBX and RSP
489c9b5090e2 Initial load
duke
parents:
diff changeset
   346
reg_class ptr_no_rax_rbx_reg(RDX, RDX_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   347
                             RBP, RBP_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   348
                             RDI, RDI_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   349
                             RSI, RSI_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   350
                             RCX, RCX_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   351
                             R8,  R8_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   352
                             R9,  R9_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   353
                             R10, R10_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   354
                             R11, R11_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   355
                             R13, R13_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   356
                             R14, R14_H);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   357
489c9b5090e2 Initial load
duke
parents:
diff changeset
   358
// Singleton class for RAX pointer register
489c9b5090e2 Initial load
duke
parents:
diff changeset
   359
reg_class ptr_rax_reg(RAX, RAX_H);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   360
489c9b5090e2 Initial load
duke
parents:
diff changeset
   361
// Singleton class for RBX pointer register
489c9b5090e2 Initial load
duke
parents:
diff changeset
   362
reg_class ptr_rbx_reg(RBX, RBX_H);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   363
489c9b5090e2 Initial load
duke
parents:
diff changeset
   364
// Singleton class for RSI pointer register
489c9b5090e2 Initial load
duke
parents:
diff changeset
   365
reg_class ptr_rsi_reg(RSI, RSI_H);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   366
489c9b5090e2 Initial load
duke
parents:
diff changeset
   367
// Singleton class for RDI pointer register
489c9b5090e2 Initial load
duke
parents:
diff changeset
   368
reg_class ptr_rdi_reg(RDI, RDI_H);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   369
489c9b5090e2 Initial load
duke
parents:
diff changeset
   370
// Singleton class for RBP pointer register
489c9b5090e2 Initial load
duke
parents:
diff changeset
   371
reg_class ptr_rbp_reg(RBP, RBP_H);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   372
489c9b5090e2 Initial load
duke
parents:
diff changeset
   373
// Singleton class for stack pointer
489c9b5090e2 Initial load
duke
parents:
diff changeset
   374
reg_class ptr_rsp_reg(RSP, RSP_H);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   375
489c9b5090e2 Initial load
duke
parents:
diff changeset
   376
// Singleton class for TLS pointer
489c9b5090e2 Initial load
duke
parents:
diff changeset
   377
reg_class ptr_r15_reg(R15, R15_H);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   378
489c9b5090e2 Initial load
duke
parents:
diff changeset
   379
// Class for all long registers (except RSP)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   380
reg_class long_reg(RAX, RAX_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   381
                   RDX, RDX_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   382
                   RBP, RBP_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   383
                   RDI, RDI_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   384
                   RSI, RSI_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   385
                   RCX, RCX_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   386
                   RBX, RBX_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   387
                   R8,  R8_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   388
                   R9,  R9_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   389
                   R10, R10_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   390
                   R11, R11_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   391
                   R13, R13_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   392
                   R14, R14_H);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   393
489c9b5090e2 Initial load
duke
parents:
diff changeset
   394
// Class for all long registers except RAX, RDX (and RSP)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   395
reg_class long_no_rax_rdx_reg(RBP, RBP_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   396
                              RDI, RDI_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   397
                              RSI, RSI_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   398
                              RCX, RCX_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   399
                              RBX, RBX_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   400
                              R8,  R8_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   401
                              R9,  R9_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   402
                              R10, R10_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   403
                              R11, R11_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   404
                              R13, R13_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   405
                              R14, R14_H);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   406
489c9b5090e2 Initial load
duke
parents:
diff changeset
   407
// Class for all long registers except RCX (and RSP)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   408
reg_class long_no_rcx_reg(RBP, RBP_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   409
                          RDI, RDI_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   410
                          RSI, RSI_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   411
                          RAX, RAX_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   412
                          RDX, RDX_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   413
                          RBX, RBX_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   414
                          R8,  R8_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   415
                          R9,  R9_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   416
                          R10, R10_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   417
                          R11, R11_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   418
                          R13, R13_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   419
                          R14, R14_H);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   420
489c9b5090e2 Initial load
duke
parents:
diff changeset
   421
// Class for all long registers except RAX (and RSP)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   422
reg_class long_no_rax_reg(RBP, RBP_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   423
                          RDX, RDX_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   424
                          RDI, RDI_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   425
                          RSI, RSI_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   426
                          RCX, RCX_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   427
                          RBX, RBX_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   428
                          R8,  R8_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   429
                          R9,  R9_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   430
                          R10, R10_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   431
                          R11, R11_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   432
                          R13, R13_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   433
                          R14, R14_H);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   434
489c9b5090e2 Initial load
duke
parents:
diff changeset
   435
// Singleton class for RAX long register
489c9b5090e2 Initial load
duke
parents:
diff changeset
   436
reg_class long_rax_reg(RAX, RAX_H);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   437
489c9b5090e2 Initial load
duke
parents:
diff changeset
   438
// Singleton class for RCX long register
489c9b5090e2 Initial load
duke
parents:
diff changeset
   439
reg_class long_rcx_reg(RCX, RCX_H);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   440
489c9b5090e2 Initial load
duke
parents:
diff changeset
   441
// Singleton class for RDX long register
489c9b5090e2 Initial load
duke
parents:
diff changeset
   442
reg_class long_rdx_reg(RDX, RDX_H);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   443
489c9b5090e2 Initial load
duke
parents:
diff changeset
   444
// Class for all int registers (except RSP)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   445
reg_class int_reg(RAX,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   446
                  RDX,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   447
                  RBP,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   448
                  RDI,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   449
                  RSI,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   450
                  RCX,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   451
                  RBX,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   452
                  R8,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   453
                  R9,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   454
                  R10,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   455
                  R11,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   456
                  R13,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   457
                  R14);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   458
489c9b5090e2 Initial load
duke
parents:
diff changeset
   459
// Class for all int registers except RCX (and RSP)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   460
reg_class int_no_rcx_reg(RAX,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   461
                         RDX,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   462
                         RBP,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   463
                         RDI,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   464
                         RSI,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   465
                         RBX,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   466
                         R8,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   467
                         R9,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   468
                         R10,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   469
                         R11,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   470
                         R13,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   471
                         R14);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   472
489c9b5090e2 Initial load
duke
parents:
diff changeset
   473
// Class for all int registers except RAX, RDX (and RSP)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   474
reg_class int_no_rax_rdx_reg(RBP,
1066
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
   475
                             RDI,
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   476
                             RSI,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   477
                             RCX,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   478
                             RBX,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   479
                             R8,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   480
                             R9,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   481
                             R10,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   482
                             R11,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   483
                             R13,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   484
                             R14);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   485
489c9b5090e2 Initial load
duke
parents:
diff changeset
   486
// Singleton class for RAX int register
489c9b5090e2 Initial load
duke
parents:
diff changeset
   487
reg_class int_rax_reg(RAX);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   488
489c9b5090e2 Initial load
duke
parents:
diff changeset
   489
// Singleton class for RBX int register
489c9b5090e2 Initial load
duke
parents:
diff changeset
   490
reg_class int_rbx_reg(RBX);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   491
489c9b5090e2 Initial load
duke
parents:
diff changeset
   492
// Singleton class for RCX int register
489c9b5090e2 Initial load
duke
parents:
diff changeset
   493
reg_class int_rcx_reg(RCX);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   494
489c9b5090e2 Initial load
duke
parents:
diff changeset
   495
// Singleton class for RCX int register
489c9b5090e2 Initial load
duke
parents:
diff changeset
   496
reg_class int_rdx_reg(RDX);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   497
489c9b5090e2 Initial load
duke
parents:
diff changeset
   498
// Singleton class for RCX int register
489c9b5090e2 Initial load
duke
parents:
diff changeset
   499
reg_class int_rdi_reg(RDI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   500
489c9b5090e2 Initial load
duke
parents:
diff changeset
   501
// Singleton class for instruction pointer
489c9b5090e2 Initial load
duke
parents:
diff changeset
   502
// reg_class ip_reg(RIP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   503
489c9b5090e2 Initial load
duke
parents:
diff changeset
   504
// Singleton class for condition codes
489c9b5090e2 Initial load
duke
parents:
diff changeset
   505
reg_class int_flags(RFLAGS);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   506
489c9b5090e2 Initial load
duke
parents:
diff changeset
   507
// Class for all float registers
489c9b5090e2 Initial load
duke
parents:
diff changeset
   508
reg_class float_reg(XMM0,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   509
                    XMM1,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   510
                    XMM2,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   511
                    XMM3,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   512
                    XMM4,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   513
                    XMM5,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   514
                    XMM6,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   515
                    XMM7,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   516
                    XMM8,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   517
                    XMM9,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   518
                    XMM10,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   519
                    XMM11,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   520
                    XMM12,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   521
                    XMM13,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   522
                    XMM14,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   523
                    XMM15);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   524
489c9b5090e2 Initial load
duke
parents:
diff changeset
   525
// Class for all double registers
489c9b5090e2 Initial load
duke
parents:
diff changeset
   526
reg_class double_reg(XMM0,  XMM0_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   527
                     XMM1,  XMM1_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   528
                     XMM2,  XMM2_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   529
                     XMM3,  XMM3_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   530
                     XMM4,  XMM4_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   531
                     XMM5,  XMM5_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   532
                     XMM6,  XMM6_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   533
                     XMM7,  XMM7_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   534
                     XMM8,  XMM8_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   535
                     XMM9,  XMM9_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   536
                     XMM10, XMM10_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   537
                     XMM11, XMM11_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   538
                     XMM12, XMM12_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   539
                     XMM13, XMM13_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   540
                     XMM14, XMM14_H,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   541
                     XMM15, XMM15_H);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   542
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   543
489c9b5090e2 Initial load
duke
parents:
diff changeset
   544
489c9b5090e2 Initial load
duke
parents:
diff changeset
   545
//----------SOURCE BLOCK-------------------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
   546
// This is a block of C++ code which provides values, functions, and
489c9b5090e2 Initial load
duke
parents:
diff changeset
   547
// definitions necessary in the rest of the architecture description
489c9b5090e2 Initial load
duke
parents:
diff changeset
   548
source %{
1066
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
   549
#define   RELOC_IMM64    Assembler::imm_operand
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   550
#define   RELOC_DISP32   Assembler::disp32_operand
489c9b5090e2 Initial load
duke
parents:
diff changeset
   551
489c9b5090e2 Initial load
duke
parents:
diff changeset
   552
#define __ _masm.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   553
4566
b363f6ef4068 6829187: compiler optimizations required for JSR 292
twisti
parents: 3908
diff changeset
   554
static int preserve_SP_size() {
b363f6ef4068 6829187: compiler optimizations required for JSR 292
twisti
parents: 3908
diff changeset
   555
  return LP64_ONLY(1 +) 2;  // [rex,] op, rm(reg/reg)
b363f6ef4068 6829187: compiler optimizations required for JSR 292
twisti
parents: 3908
diff changeset
   556
}
b363f6ef4068 6829187: compiler optimizations required for JSR 292
twisti
parents: 3908
diff changeset
   557
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   558
// !!!!! Special hack to get all types of calls to specify the byte offset
489c9b5090e2 Initial load
duke
parents:
diff changeset
   559
//       from the start of the call to the point where the return address
489c9b5090e2 Initial load
duke
parents:
diff changeset
   560
//       will point.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   561
int MachCallStaticJavaNode::ret_addr_offset()
489c9b5090e2 Initial load
duke
parents:
diff changeset
   562
{
4566
b363f6ef4068 6829187: compiler optimizations required for JSR 292
twisti
parents: 3908
diff changeset
   563
  int offset = 5; // 5 bytes from start of call to where return address points
b363f6ef4068 6829187: compiler optimizations required for JSR 292
twisti
parents: 3908
diff changeset
   564
  if (_method_handle_invoke)
b363f6ef4068 6829187: compiler optimizations required for JSR 292
twisti
parents: 3908
diff changeset
   565
    offset += preserve_SP_size();
b363f6ef4068 6829187: compiler optimizations required for JSR 292
twisti
parents: 3908
diff changeset
   566
  return offset;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   567
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   568
489c9b5090e2 Initial load
duke
parents:
diff changeset
   569
int MachCallDynamicJavaNode::ret_addr_offset()
489c9b5090e2 Initial load
duke
parents:
diff changeset
   570
{
489c9b5090e2 Initial load
duke
parents:
diff changeset
   571
  return 15; // 15 bytes from start of call to where return address points
489c9b5090e2 Initial load
duke
parents:
diff changeset
   572
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   573
489c9b5090e2 Initial load
duke
parents:
diff changeset
   574
// In os_cpu .ad file
489c9b5090e2 Initial load
duke
parents:
diff changeset
   575
// int MachCallRuntimeNode::ret_addr_offset()
489c9b5090e2 Initial load
duke
parents:
diff changeset
   576
489c9b5090e2 Initial load
duke
parents:
diff changeset
   577
// Indicate if the safepoint node needs the polling page as an input.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   578
// Since amd64 does not have absolute addressing but RIP-relative
489c9b5090e2 Initial load
duke
parents:
diff changeset
   579
// addressing and the polling page is within 2G, it doesn't.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   580
bool SafePointNode::needs_polling_address_input()
489c9b5090e2 Initial load
duke
parents:
diff changeset
   581
{
489c9b5090e2 Initial load
duke
parents:
diff changeset
   582
  return false;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   583
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   584
489c9b5090e2 Initial load
duke
parents:
diff changeset
   585
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
   586
// Compute padding required for nodes which need alignment
489c9b5090e2 Initial load
duke
parents:
diff changeset
   587
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
   588
489c9b5090e2 Initial load
duke
parents:
diff changeset
   589
// The address of the call instruction needs to be 4-byte aligned to
489c9b5090e2 Initial load
duke
parents:
diff changeset
   590
// ensure that it does not span a cache line so that it can be patched.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   591
int CallStaticJavaDirectNode::compute_padding(int current_offset) const
489c9b5090e2 Initial load
duke
parents:
diff changeset
   592
{
489c9b5090e2 Initial load
duke
parents:
diff changeset
   593
  current_offset += 1; // skip call opcode byte
489c9b5090e2 Initial load
duke
parents:
diff changeset
   594
  return round_to(current_offset, alignment_required()) - current_offset;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   595
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   596
489c9b5090e2 Initial load
duke
parents:
diff changeset
   597
// The address of the call instruction needs to be 4-byte aligned to
489c9b5090e2 Initial load
duke
parents:
diff changeset
   598
// ensure that it does not span a cache line so that it can be patched.
4566
b363f6ef4068 6829187: compiler optimizations required for JSR 292
twisti
parents: 3908
diff changeset
   599
int CallStaticJavaHandleNode::compute_padding(int current_offset) const
b363f6ef4068 6829187: compiler optimizations required for JSR 292
twisti
parents: 3908
diff changeset
   600
{
b363f6ef4068 6829187: compiler optimizations required for JSR 292
twisti
parents: 3908
diff changeset
   601
  current_offset += preserve_SP_size();   // skip mov rbp, rsp
b363f6ef4068 6829187: compiler optimizations required for JSR 292
twisti
parents: 3908
diff changeset
   602
  current_offset += 1; // skip call opcode byte
b363f6ef4068 6829187: compiler optimizations required for JSR 292
twisti
parents: 3908
diff changeset
   603
  return round_to(current_offset, alignment_required()) - current_offset;
b363f6ef4068 6829187: compiler optimizations required for JSR 292
twisti
parents: 3908
diff changeset
   604
}
b363f6ef4068 6829187: compiler optimizations required for JSR 292
twisti
parents: 3908
diff changeset
   605
b363f6ef4068 6829187: compiler optimizations required for JSR 292
twisti
parents: 3908
diff changeset
   606
// 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
   607
// ensure that it does not span a cache line so that it can be patched.
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   608
int CallDynamicJavaDirectNode::compute_padding(int current_offset) const
489c9b5090e2 Initial load
duke
parents:
diff changeset
   609
{
489c9b5090e2 Initial load
duke
parents:
diff changeset
   610
  current_offset += 11; // skip movq instruction + call opcode byte
489c9b5090e2 Initial load
duke
parents:
diff changeset
   611
  return round_to(current_offset, alignment_required()) - current_offset;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   612
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   613
489c9b5090e2 Initial load
duke
parents:
diff changeset
   614
#ifndef PRODUCT
489c9b5090e2 Initial load
duke
parents:
diff changeset
   615
void MachBreakpointNode::format(PhaseRegAlloc*, outputStream* st) const
489c9b5090e2 Initial load
duke
parents:
diff changeset
   616
{
489c9b5090e2 Initial load
duke
parents:
diff changeset
   617
  st->print("INT3");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   618
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   619
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
   620
489c9b5090e2 Initial load
duke
parents:
diff changeset
   621
// EMIT_RM()
489c9b5090e2 Initial load
duke
parents:
diff changeset
   622
void emit_rm(CodeBuffer &cbuf, int f1, int f2, int f3)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   623
{
489c9b5090e2 Initial load
duke
parents:
diff changeset
   624
  unsigned char c = (unsigned char) ((f1 << 6) | (f2 << 3) | f3);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   625
  *(cbuf.code_end()) = c;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   626
  cbuf.set_code_end(cbuf.code_end() + 1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   627
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   628
489c9b5090e2 Initial load
duke
parents:
diff changeset
   629
// EMIT_CC()
489c9b5090e2 Initial load
duke
parents:
diff changeset
   630
void emit_cc(CodeBuffer &cbuf, int f1, int f2)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   631
{
489c9b5090e2 Initial load
duke
parents:
diff changeset
   632
  unsigned char c = (unsigned char) (f1 | f2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   633
  *(cbuf.code_end()) = c;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   634
  cbuf.set_code_end(cbuf.code_end() + 1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   635
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   636
489c9b5090e2 Initial load
duke
parents:
diff changeset
   637
// EMIT_OPCODE()
489c9b5090e2 Initial load
duke
parents:
diff changeset
   638
void emit_opcode(CodeBuffer &cbuf, int code)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   639
{
489c9b5090e2 Initial load
duke
parents:
diff changeset
   640
  *(cbuf.code_end()) = (unsigned char) code;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   641
  cbuf.set_code_end(cbuf.code_end() + 1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   642
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   643
489c9b5090e2 Initial load
duke
parents:
diff changeset
   644
// EMIT_OPCODE() w/ relocation information
489c9b5090e2 Initial load
duke
parents:
diff changeset
   645
void emit_opcode(CodeBuffer &cbuf,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   646
                 int code, relocInfo::relocType reloc, int offset, int format)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   647
{
489c9b5090e2 Initial load
duke
parents:
diff changeset
   648
  cbuf.relocate(cbuf.inst_mark() + offset, reloc, format);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   649
  emit_opcode(cbuf, code);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   650
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   651
489c9b5090e2 Initial load
duke
parents:
diff changeset
   652
// EMIT_D8()
489c9b5090e2 Initial load
duke
parents:
diff changeset
   653
void emit_d8(CodeBuffer &cbuf, int d8)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   654
{
489c9b5090e2 Initial load
duke
parents:
diff changeset
   655
  *(cbuf.code_end()) = (unsigned char) d8;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   656
  cbuf.set_code_end(cbuf.code_end() + 1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   657
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   658
489c9b5090e2 Initial load
duke
parents:
diff changeset
   659
// EMIT_D16()
489c9b5090e2 Initial load
duke
parents:
diff changeset
   660
void emit_d16(CodeBuffer &cbuf, int d16)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   661
{
489c9b5090e2 Initial load
duke
parents:
diff changeset
   662
  *((short *)(cbuf.code_end())) = d16;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   663
  cbuf.set_code_end(cbuf.code_end() + 2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   664
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   665
489c9b5090e2 Initial load
duke
parents:
diff changeset
   666
// EMIT_D32()
489c9b5090e2 Initial load
duke
parents:
diff changeset
   667
void emit_d32(CodeBuffer &cbuf, int d32)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   668
{
489c9b5090e2 Initial load
duke
parents:
diff changeset
   669
  *((int *)(cbuf.code_end())) = d32;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   670
  cbuf.set_code_end(cbuf.code_end() + 4);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   671
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   672
489c9b5090e2 Initial load
duke
parents:
diff changeset
   673
// EMIT_D64()
489c9b5090e2 Initial load
duke
parents:
diff changeset
   674
void emit_d64(CodeBuffer &cbuf, int64_t d64)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   675
{
489c9b5090e2 Initial load
duke
parents:
diff changeset
   676
  *((int64_t*) (cbuf.code_end())) = d64;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   677
  cbuf.set_code_end(cbuf.code_end() + 8);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   678
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   679
489c9b5090e2 Initial load
duke
parents:
diff changeset
   680
// emit 32 bit value and construct relocation entry from relocInfo::relocType
489c9b5090e2 Initial load
duke
parents:
diff changeset
   681
void emit_d32_reloc(CodeBuffer& cbuf,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   682
                    int d32,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   683
                    relocInfo::relocType reloc,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   684
                    int format)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   685
{
489c9b5090e2 Initial load
duke
parents:
diff changeset
   686
  assert(reloc != relocInfo::external_word_type, "use 2-arg emit_d32_reloc");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   687
  cbuf.relocate(cbuf.inst_mark(), reloc, format);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   688
489c9b5090e2 Initial load
duke
parents:
diff changeset
   689
  *((int*) (cbuf.code_end())) = d32;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   690
  cbuf.set_code_end(cbuf.code_end() + 4);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   691
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   692
489c9b5090e2 Initial load
duke
parents:
diff changeset
   693
// emit 32 bit value and construct relocation entry from RelocationHolder
489c9b5090e2 Initial load
duke
parents:
diff changeset
   694
void emit_d32_reloc(CodeBuffer& cbuf,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   695
                    int d32,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   696
                    RelocationHolder const& rspec,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   697
                    int format)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   698
{
489c9b5090e2 Initial load
duke
parents:
diff changeset
   699
#ifdef ASSERT
489c9b5090e2 Initial load
duke
parents:
diff changeset
   700
  if (rspec.reloc()->type() == relocInfo::oop_type &&
489c9b5090e2 Initial load
duke
parents:
diff changeset
   701
      d32 != 0 && d32 != (intptr_t) Universe::non_oop_word()) {
3908
24b55ad4c228 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 3905
diff changeset
   702
    assert(oop((intptr_t)d32)->is_oop() && (ScavengeRootsInCode || !oop((intptr_t)d32)->is_scavengable()), "cannot embed scavengable oops in code");
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   703
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   704
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
   705
  cbuf.relocate(cbuf.inst_mark(), rspec, format);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   706
489c9b5090e2 Initial load
duke
parents:
diff changeset
   707
  *((int* )(cbuf.code_end())) = d32;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   708
  cbuf.set_code_end(cbuf.code_end() + 4);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   709
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   710
489c9b5090e2 Initial load
duke
parents:
diff changeset
   711
void emit_d32_reloc(CodeBuffer& cbuf, address addr) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   712
  address next_ip = cbuf.code_end() + 4;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   713
  emit_d32_reloc(cbuf, (int) (addr - next_ip),
489c9b5090e2 Initial load
duke
parents:
diff changeset
   714
                 external_word_Relocation::spec(addr),
489c9b5090e2 Initial load
duke
parents:
diff changeset
   715
                 RELOC_DISP32);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   716
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   717
489c9b5090e2 Initial load
duke
parents:
diff changeset
   718
489c9b5090e2 Initial load
duke
parents:
diff changeset
   719
// emit 64 bit value and construct relocation entry from relocInfo::relocType
489c9b5090e2 Initial load
duke
parents:
diff changeset
   720
void emit_d64_reloc(CodeBuffer& cbuf,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   721
                    int64_t d64,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   722
                    relocInfo::relocType reloc,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   723
                    int format)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   724
{
489c9b5090e2 Initial load
duke
parents:
diff changeset
   725
  cbuf.relocate(cbuf.inst_mark(), reloc, format);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   726
489c9b5090e2 Initial load
duke
parents:
diff changeset
   727
  *((int64_t*) (cbuf.code_end())) = d64;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   728
  cbuf.set_code_end(cbuf.code_end() + 8);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   729
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   730
489c9b5090e2 Initial load
duke
parents:
diff changeset
   731
// emit 64 bit value and construct relocation entry from RelocationHolder
489c9b5090e2 Initial load
duke
parents:
diff changeset
   732
void emit_d64_reloc(CodeBuffer& cbuf,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   733
                    int64_t d64,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   734
                    RelocationHolder const& rspec,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   735
                    int format)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   736
{
489c9b5090e2 Initial load
duke
parents:
diff changeset
   737
#ifdef ASSERT
489c9b5090e2 Initial load
duke
parents:
diff changeset
   738
  if (rspec.reloc()->type() == relocInfo::oop_type &&
489c9b5090e2 Initial load
duke
parents:
diff changeset
   739
      d64 != 0 && d64 != (int64_t) Universe::non_oop_word()) {
3908
24b55ad4c228 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 3905
diff changeset
   740
    assert(oop(d64)->is_oop() && (ScavengeRootsInCode || !oop(d64)->is_scavengable()),
24b55ad4c228 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 3905
diff changeset
   741
           "cannot embed scavengable oops in code");
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   742
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   743
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
   744
  cbuf.relocate(cbuf.inst_mark(), rspec, format);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   745
489c9b5090e2 Initial load
duke
parents:
diff changeset
   746
  *((int64_t*) (cbuf.code_end())) = d64;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   747
  cbuf.set_code_end(cbuf.code_end() + 8);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   748
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   749
489c9b5090e2 Initial load
duke
parents:
diff changeset
   750
// Access stack slot for load or store
489c9b5090e2 Initial load
duke
parents:
diff changeset
   751
void store_to_stackslot(CodeBuffer &cbuf, int opcode, int rm_field, int disp)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   752
{
489c9b5090e2 Initial load
duke
parents:
diff changeset
   753
  emit_opcode(cbuf, opcode);                  // (e.g., FILD   [RSP+src])
489c9b5090e2 Initial load
duke
parents:
diff changeset
   754
  if (-0x80 <= disp && disp < 0x80) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   755
    emit_rm(cbuf, 0x01, rm_field, RSP_enc);   // R/M byte
489c9b5090e2 Initial load
duke
parents:
diff changeset
   756
    emit_rm(cbuf, 0x00, RSP_enc, RSP_enc);    // SIB byte
489c9b5090e2 Initial load
duke
parents:
diff changeset
   757
    emit_d8(cbuf, disp);     // Displacement  // R/M byte
489c9b5090e2 Initial load
duke
parents:
diff changeset
   758
  } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   759
    emit_rm(cbuf, 0x02, rm_field, RSP_enc);   // R/M byte
489c9b5090e2 Initial load
duke
parents:
diff changeset
   760
    emit_rm(cbuf, 0x00, RSP_enc, RSP_enc);    // SIB byte
489c9b5090e2 Initial load
duke
parents:
diff changeset
   761
    emit_d32(cbuf, disp);     // Displacement // R/M byte
489c9b5090e2 Initial load
duke
parents:
diff changeset
   762
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   763
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   764
489c9b5090e2 Initial load
duke
parents:
diff changeset
   765
   // rRegI ereg, memory mem) %{    // emit_reg_mem
489c9b5090e2 Initial load
duke
parents:
diff changeset
   766
void encode_RegMem(CodeBuffer &cbuf,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   767
                   int reg,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   768
                   int base, int index, int scale, int disp, bool disp_is_oop)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   769
{
489c9b5090e2 Initial load
duke
parents:
diff changeset
   770
  assert(!disp_is_oop, "cannot have disp");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   771
  int regenc = reg & 7;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   772
  int baseenc = base & 7;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   773
  int indexenc = index & 7;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   774
489c9b5090e2 Initial load
duke
parents:
diff changeset
   775
  // There is no index & no scale, use form without SIB byte
489c9b5090e2 Initial load
duke
parents:
diff changeset
   776
  if (index == 0x4 && scale == 0 && base != RSP_enc && base != R12_enc) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   777
    // If no displacement, mode is 0x0; unless base is [RBP] or [R13]
489c9b5090e2 Initial load
duke
parents:
diff changeset
   778
    if (disp == 0 && base != RBP_enc && base != R13_enc) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   779
      emit_rm(cbuf, 0x0, regenc, baseenc); // *
489c9b5090e2 Initial load
duke
parents:
diff changeset
   780
    } else if (-0x80 <= disp && disp < 0x80 && !disp_is_oop) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   781
      // If 8-bit displacement, mode 0x1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   782
      emit_rm(cbuf, 0x1, regenc, baseenc); // *
489c9b5090e2 Initial load
duke
parents:
diff changeset
   783
      emit_d8(cbuf, disp);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   784
    } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   785
      // If 32-bit displacement
489c9b5090e2 Initial load
duke
parents:
diff changeset
   786
      if (base == -1) { // Special flag for absolute address
489c9b5090e2 Initial load
duke
parents:
diff changeset
   787
        emit_rm(cbuf, 0x0, regenc, 0x5); // *
489c9b5090e2 Initial load
duke
parents:
diff changeset
   788
        if (disp_is_oop) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   789
          emit_d32_reloc(cbuf, disp, relocInfo::oop_type, RELOC_DISP32);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   790
        } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   791
          emit_d32(cbuf, disp);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   792
        }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   793
      } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   794
        // Normal base + offset
489c9b5090e2 Initial load
duke
parents:
diff changeset
   795
        emit_rm(cbuf, 0x2, regenc, baseenc); // *
489c9b5090e2 Initial load
duke
parents:
diff changeset
   796
        if (disp_is_oop) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   797
          emit_d32_reloc(cbuf, disp, relocInfo::oop_type, RELOC_DISP32);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   798
        } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   799
          emit_d32(cbuf, disp);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   800
        }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   801
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   802
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   803
  } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   804
    // Else, encode with the SIB byte
489c9b5090e2 Initial load
duke
parents:
diff changeset
   805
    // If no displacement, mode is 0x0; unless base is [RBP] or [R13]
489c9b5090e2 Initial load
duke
parents:
diff changeset
   806
    if (disp == 0 && base != RBP_enc && base != R13_enc) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   807
      // If no displacement
489c9b5090e2 Initial load
duke
parents:
diff changeset
   808
      emit_rm(cbuf, 0x0, regenc, 0x4); // *
489c9b5090e2 Initial load
duke
parents:
diff changeset
   809
      emit_rm(cbuf, scale, indexenc, baseenc);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   810
    } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   811
      if (-0x80 <= disp && disp < 0x80 && !disp_is_oop) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   812
        // If 8-bit displacement, mode 0x1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   813
        emit_rm(cbuf, 0x1, regenc, 0x4); // *
489c9b5090e2 Initial load
duke
parents:
diff changeset
   814
        emit_rm(cbuf, scale, indexenc, baseenc);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   815
        emit_d8(cbuf, disp);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   816
      } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   817
        // If 32-bit displacement
489c9b5090e2 Initial load
duke
parents:
diff changeset
   818
        if (base == 0x04 ) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   819
          emit_rm(cbuf, 0x2, regenc, 0x4);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   820
          emit_rm(cbuf, scale, indexenc, 0x04); // XXX is this valid???
489c9b5090e2 Initial load
duke
parents:
diff changeset
   821
        } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   822
          emit_rm(cbuf, 0x2, regenc, 0x4);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   823
          emit_rm(cbuf, scale, indexenc, baseenc); // *
489c9b5090e2 Initial load
duke
parents:
diff changeset
   824
        }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   825
        if (disp_is_oop) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   826
          emit_d32_reloc(cbuf, disp, relocInfo::oop_type, RELOC_DISP32);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   827
        } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   828
          emit_d32(cbuf, disp);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   829
        }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   830
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   831
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   832
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   833
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   834
489c9b5090e2 Initial load
duke
parents:
diff changeset
   835
void encode_copy(CodeBuffer &cbuf, int dstenc, int srcenc)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   836
{
489c9b5090e2 Initial load
duke
parents:
diff changeset
   837
  if (dstenc != srcenc) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   838
    if (dstenc < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   839
      if (srcenc >= 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   840
        emit_opcode(cbuf, Assembler::REX_B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   841
        srcenc -= 8;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   842
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   843
    } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   844
      if (srcenc < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   845
        emit_opcode(cbuf, Assembler::REX_R);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   846
      } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   847
        emit_opcode(cbuf, Assembler::REX_RB);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   848
        srcenc -= 8;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   849
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   850
      dstenc -= 8;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   851
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   852
489c9b5090e2 Initial load
duke
parents:
diff changeset
   853
    emit_opcode(cbuf, 0x8B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   854
    emit_rm(cbuf, 0x3, dstenc, srcenc);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   855
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   856
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   857
489c9b5090e2 Initial load
duke
parents:
diff changeset
   858
void encode_CopyXD( CodeBuffer &cbuf, int dst_encoding, int src_encoding ) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   859
  if( dst_encoding == src_encoding ) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   860
    // reg-reg copy, use an empty encoding
489c9b5090e2 Initial load
duke
parents:
diff changeset
   861
  } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   862
    MacroAssembler _masm(&cbuf);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   863
489c9b5090e2 Initial load
duke
parents:
diff changeset
   864
    __ movdqa(as_XMMRegister(dst_encoding), as_XMMRegister(src_encoding));
489c9b5090e2 Initial load
duke
parents:
diff changeset
   865
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   866
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   867
489c9b5090e2 Initial load
duke
parents:
diff changeset
   868
489c9b5090e2 Initial load
duke
parents:
diff changeset
   869
//=============================================================================
489c9b5090e2 Initial load
duke
parents:
diff changeset
   870
#ifndef PRODUCT
489c9b5090e2 Initial load
duke
parents:
diff changeset
   871
void MachPrologNode::format(PhaseRegAlloc* ra_, outputStream* st) const
489c9b5090e2 Initial load
duke
parents:
diff changeset
   872
{
489c9b5090e2 Initial load
duke
parents:
diff changeset
   873
  Compile* C = ra_->C;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   874
489c9b5090e2 Initial load
duke
parents:
diff changeset
   875
  int framesize = C->frame_slots() << LogBytesPerInt;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   876
  assert((framesize & (StackAlignmentInBytes-1)) == 0, "frame size not aligned");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   877
  // Remove wordSize for return adr already pushed
489c9b5090e2 Initial load
duke
parents:
diff changeset
   878
  // and another for the RBP we are going to save
489c9b5090e2 Initial load
duke
parents:
diff changeset
   879
  framesize -= 2*wordSize;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   880
  bool need_nop = true;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   881
489c9b5090e2 Initial load
duke
parents:
diff changeset
   882
  // Calls to C2R adapters often do not accept exceptional returns.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   883
  // We require that their callers must bang for them.  But be
489c9b5090e2 Initial load
duke
parents:
diff changeset
   884
  // careful, because some VM calls (such as call site linkage) can
489c9b5090e2 Initial load
duke
parents:
diff changeset
   885
  // use several kilobytes of stack.  But the stack safety zone should
489c9b5090e2 Initial load
duke
parents:
diff changeset
   886
  // account for that.  See bugs 4446381, 4468289, 4497237.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   887
  if (C->need_stack_bang(framesize)) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   888
    st->print_cr("# stack bang"); st->print("\t");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   889
    need_nop = false;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   890
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   891
  st->print_cr("pushq   rbp"); st->print("\t");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   892
489c9b5090e2 Initial load
duke
parents:
diff changeset
   893
  if (VerifyStackAtCalls) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   894
    // Majik cookie to verify stack depth
489c9b5090e2 Initial load
duke
parents:
diff changeset
   895
    st->print_cr("pushq   0xffffffffbadb100d"
489c9b5090e2 Initial load
duke
parents:
diff changeset
   896
                  "\t# Majik cookie for stack depth check");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   897
    st->print("\t");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   898
    framesize -= wordSize; // Remove 2 for cookie
489c9b5090e2 Initial load
duke
parents:
diff changeset
   899
    need_nop = false;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   900
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   901
489c9b5090e2 Initial load
duke
parents:
diff changeset
   902
  if (framesize) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   903
    st->print("subq    rsp, #%d\t# Create frame", framesize);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   904
    if (framesize < 0x80 && need_nop) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   905
      st->print("\n\tnop\t# nop for patch_verified_entry");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   906
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   907
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   908
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   909
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
   910
489c9b5090e2 Initial load
duke
parents:
diff changeset
   911
void MachPrologNode::emit(CodeBuffer &cbuf, PhaseRegAlloc *ra_) const
489c9b5090e2 Initial load
duke
parents:
diff changeset
   912
{
489c9b5090e2 Initial load
duke
parents:
diff changeset
   913
  Compile* C = ra_->C;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   914
489c9b5090e2 Initial load
duke
parents:
diff changeset
   915
  // WARNING: Initial instruction MUST be 5 bytes or longer so that
489c9b5090e2 Initial load
duke
parents:
diff changeset
   916
  // NativeJump::patch_verified_entry will be able to patch out the entry
489c9b5090e2 Initial load
duke
parents:
diff changeset
   917
  // code safely. The fldcw is ok at 6 bytes, the push to verify stack
489c9b5090e2 Initial load
duke
parents:
diff changeset
   918
  // depth is ok at 5 bytes, the frame allocation can be either 3 or
489c9b5090e2 Initial load
duke
parents:
diff changeset
   919
  // 6 bytes. So if we don't do the fldcw or the push then we must
489c9b5090e2 Initial load
duke
parents:
diff changeset
   920
  // use the 6 byte frame allocation even if we have no frame. :-(
489c9b5090e2 Initial load
duke
parents:
diff changeset
   921
  // If method sets FPU control word do it now
489c9b5090e2 Initial load
duke
parents:
diff changeset
   922
489c9b5090e2 Initial load
duke
parents:
diff changeset
   923
  int framesize = C->frame_slots() << LogBytesPerInt;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   924
  assert((framesize & (StackAlignmentInBytes-1)) == 0, "frame size not aligned");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   925
  // Remove wordSize for return adr already pushed
489c9b5090e2 Initial load
duke
parents:
diff changeset
   926
  // and another for the RBP we are going to save
489c9b5090e2 Initial load
duke
parents:
diff changeset
   927
  framesize -= 2*wordSize;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   928
  bool need_nop = true;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   929
489c9b5090e2 Initial load
duke
parents:
diff changeset
   930
  // Calls to C2R adapters often do not accept exceptional returns.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   931
  // We require that their callers must bang for them.  But be
489c9b5090e2 Initial load
duke
parents:
diff changeset
   932
  // careful, because some VM calls (such as call site linkage) can
489c9b5090e2 Initial load
duke
parents:
diff changeset
   933
  // use several kilobytes of stack.  But the stack safety zone should
489c9b5090e2 Initial load
duke
parents:
diff changeset
   934
  // account for that.  See bugs 4446381, 4468289, 4497237.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   935
  if (C->need_stack_bang(framesize)) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   936
    MacroAssembler masm(&cbuf);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   937
    masm.generate_stack_overflow_check(framesize);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   938
    need_nop = false;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   939
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   940
489c9b5090e2 Initial load
duke
parents:
diff changeset
   941
  // We always push rbp so that on return to interpreter rbp will be
489c9b5090e2 Initial load
duke
parents:
diff changeset
   942
  // restored correctly and we can correct the stack.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   943
  emit_opcode(cbuf, 0x50 | RBP_enc);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   944
489c9b5090e2 Initial load
duke
parents:
diff changeset
   945
  if (VerifyStackAtCalls) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   946
    // Majik cookie to verify stack depth
489c9b5090e2 Initial load
duke
parents:
diff changeset
   947
    emit_opcode(cbuf, 0x68); // pushq (sign-extended) 0xbadb100d
489c9b5090e2 Initial load
duke
parents:
diff changeset
   948
    emit_d32(cbuf, 0xbadb100d);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   949
    framesize -= wordSize; // Remove 2 for cookie
489c9b5090e2 Initial load
duke
parents:
diff changeset
   950
    need_nop = false;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   951
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   952
489c9b5090e2 Initial load
duke
parents:
diff changeset
   953
  if (framesize) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   954
    emit_opcode(cbuf, Assembler::REX_W);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   955
    if (framesize < 0x80) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   956
      emit_opcode(cbuf, 0x83);   // sub  SP,#framesize
489c9b5090e2 Initial load
duke
parents:
diff changeset
   957
      emit_rm(cbuf, 0x3, 0x05, RSP_enc);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   958
      emit_d8(cbuf, framesize);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   959
      if (need_nop) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   960
        emit_opcode(cbuf, 0x90); // nop
489c9b5090e2 Initial load
duke
parents:
diff changeset
   961
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   962
    } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   963
      emit_opcode(cbuf, 0x81);   // sub  SP,#framesize
489c9b5090e2 Initial load
duke
parents:
diff changeset
   964
      emit_rm(cbuf, 0x3, 0x05, RSP_enc);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   965
      emit_d32(cbuf, framesize);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   966
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   967
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   968
489c9b5090e2 Initial load
duke
parents:
diff changeset
   969
  C->set_frame_complete(cbuf.code_end() - cbuf.code_begin());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   970
489c9b5090e2 Initial load
duke
parents:
diff changeset
   971
#ifdef ASSERT
489c9b5090e2 Initial load
duke
parents:
diff changeset
   972
  if (VerifyStackAtCalls) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   973
    Label L;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   974
    MacroAssembler masm(&cbuf);
1066
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
   975
    masm.push(rax);
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
   976
    masm.mov(rax, rsp);
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
   977
    masm.andptr(rax, StackAlignmentInBytes-1);
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
   978
    masm.cmpptr(rax, StackAlignmentInBytes-wordSize);
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
   979
    masm.pop(rax);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   980
    masm.jcc(Assembler::equal, L);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   981
    masm.stop("Stack is not properly aligned!");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   982
    masm.bind(L);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   983
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   984
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
   985
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   986
489c9b5090e2 Initial load
duke
parents:
diff changeset
   987
uint MachPrologNode::size(PhaseRegAlloc* ra_) const
489c9b5090e2 Initial load
duke
parents:
diff changeset
   988
{
489c9b5090e2 Initial load
duke
parents:
diff changeset
   989
  return MachNode::size(ra_); // too many variables; just compute it
489c9b5090e2 Initial load
duke
parents:
diff changeset
   990
                              // the hard way
489c9b5090e2 Initial load
duke
parents:
diff changeset
   991
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   992
489c9b5090e2 Initial load
duke
parents:
diff changeset
   993
int MachPrologNode::reloc() const
489c9b5090e2 Initial load
duke
parents:
diff changeset
   994
{
489c9b5090e2 Initial load
duke
parents:
diff changeset
   995
  return 0; // a large enough number
489c9b5090e2 Initial load
duke
parents:
diff changeset
   996
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   997
489c9b5090e2 Initial load
duke
parents:
diff changeset
   998
//=============================================================================
489c9b5090e2 Initial load
duke
parents:
diff changeset
   999
#ifndef PRODUCT
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1000
void MachEpilogNode::format(PhaseRegAlloc* ra_, outputStream* st) const
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1001
{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1002
  Compile* C = ra_->C;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1003
  int framesize = C->frame_slots() << LogBytesPerInt;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1004
  assert((framesize & (StackAlignmentInBytes-1)) == 0, "frame size not aligned");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1005
  // Remove word for return adr already pushed
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1006
  // and RBP
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1007
  framesize -= 2*wordSize;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1008
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1009
  if (framesize) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1010
    st->print_cr("addq\trsp, %d\t# Destroy frame", framesize);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1011
    st->print("\t");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1012
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1013
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1014
  st->print_cr("popq\trbp");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1015
  if (do_polling() && C->is_method_compilation()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1016
    st->print_cr("\ttestl\trax, [rip + #offset_to_poll_page]\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1017
                  "# Safepoint: poll for GC");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1018
    st->print("\t");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1019
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1020
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1021
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1022
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1023
void MachEpilogNode::emit(CodeBuffer& cbuf, PhaseRegAlloc* ra_) const
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1024
{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1025
  Compile* C = ra_->C;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1026
  int framesize = C->frame_slots() << LogBytesPerInt;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1027
  assert((framesize & (StackAlignmentInBytes-1)) == 0, "frame size not aligned");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1028
  // Remove word for return adr already pushed
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1029
  // and RBP
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1030
  framesize -= 2*wordSize;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1031
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1032
  // Note that VerifyStackAtCalls' Majik cookie does not change the frame size popped here
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1033
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1034
  if (framesize) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1035
    emit_opcode(cbuf, Assembler::REX_W);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1036
    if (framesize < 0x80) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1037
      emit_opcode(cbuf, 0x83); // addq rsp, #framesize
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1038
      emit_rm(cbuf, 0x3, 0x00, RSP_enc);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1039
      emit_d8(cbuf, framesize);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1040
    } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1041
      emit_opcode(cbuf, 0x81); // addq rsp, #framesize
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1042
      emit_rm(cbuf, 0x3, 0x00, RSP_enc);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1043
      emit_d32(cbuf, framesize);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1044
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1045
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1046
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1047
  // popq rbp
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1048
  emit_opcode(cbuf, 0x58 | RBP_enc);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1049
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1050
  if (do_polling() && C->is_method_compilation()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1051
    // testl %rax, off(%rip) // Opcode + ModRM + Disp32 == 6 bytes
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1052
    // XXX reg_mem doesn't support RIP-relative addressing yet
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1053
    cbuf.set_inst_mark();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1054
    cbuf.relocate(cbuf.inst_mark(), relocInfo::poll_return_type, 0); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1055
    emit_opcode(cbuf, 0x85); // testl
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1056
    emit_rm(cbuf, 0x0, RAX_enc, 0x5); // 00 rax 101 == 0x5
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1057
    // cbuf.inst_mark() is beginning of instruction
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1058
    emit_d32_reloc(cbuf, os::get_polling_page());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1059
//                    relocInfo::poll_return_type,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1060
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1061
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1062
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1063
uint MachEpilogNode::size(PhaseRegAlloc* ra_) const
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1064
{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1065
  Compile* C = ra_->C;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1066
  int framesize = C->frame_slots() << LogBytesPerInt;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1067
  assert((framesize & (StackAlignmentInBytes-1)) == 0, "frame size not aligned");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1068
  // Remove word for return adr already pushed
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1069
  // and RBP
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1070
  framesize -= 2*wordSize;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1071
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1072
  uint size = 0;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1073
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1074
  if (do_polling() && C->is_method_compilation()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1075
    size += 6;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1076
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1077
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1078
  // count popq rbp
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1079
  size++;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1080
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1081
  if (framesize) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1082
    if (framesize < 0x80) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1083
      size += 4;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1084
    } else if (framesize) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1085
      size += 7;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1086
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1087
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1088
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1089
  return size;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1090
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1091
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1092
int MachEpilogNode::reloc() const
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1093
{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1094
  return 2; // a large enough number
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1095
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1096
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1097
const Pipeline* MachEpilogNode::pipeline() const
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1098
{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1099
  return MachNode::pipeline_class();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1100
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1101
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1102
int MachEpilogNode::safepoint_offset() const
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1103
{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1104
  return 0;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1105
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1106
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1107
//=============================================================================
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1108
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1109
enum RC {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1110
  rc_bad,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1111
  rc_int,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1112
  rc_float,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1113
  rc_stack
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1114
};
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1115
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1116
static enum RC rc_class(OptoReg::Name reg)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1117
{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1118
  if( !OptoReg::is_valid(reg)  ) return rc_bad;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1119
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1120
  if (OptoReg::is_stack(reg)) return rc_stack;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1121
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1122
  VMReg r = OptoReg::as_VMReg(reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1123
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1124
  if (r->is_Register()) return rc_int;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1125
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1126
  assert(r->is_XMMRegister(), "must be");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1127
  return rc_float;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1128
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1129
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1130
uint MachSpillCopyNode::implementation(CodeBuffer* cbuf,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1131
                                       PhaseRegAlloc* ra_,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1132
                                       bool do_size,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1133
                                       outputStream* st) const
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1134
{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1135
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1136
  // Get registers to move
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1137
  OptoReg::Name src_second = ra_->get_reg_second(in(1));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1138
  OptoReg::Name src_first = ra_->get_reg_first(in(1));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1139
  OptoReg::Name dst_second = ra_->get_reg_second(this);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1140
  OptoReg::Name dst_first = ra_->get_reg_first(this);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1141
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1142
  enum RC src_second_rc = rc_class(src_second);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1143
  enum RC src_first_rc = rc_class(src_first);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1144
  enum RC dst_second_rc = rc_class(dst_second);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1145
  enum RC dst_first_rc = rc_class(dst_first);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1146
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1147
  assert(OptoReg::is_valid(src_first) && OptoReg::is_valid(dst_first),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1148
         "must move at least 1 register" );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1149
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1150
  if (src_first == dst_first && src_second == dst_second) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1151
    // Self copy, no move
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1152
    return 0;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1153
  } else if (src_first_rc == rc_stack) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1154
    // mem ->
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1155
    if (dst_first_rc == rc_stack) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1156
      // mem -> mem
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1157
      assert(src_second != dst_first, "overlap");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1158
      if ((src_first & 1) == 0 && src_first + 1 == src_second &&
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1159
          (dst_first & 1) == 0 && dst_first + 1 == dst_second) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1160
        // 64-bit
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1161
        int src_offset = ra_->reg2offset(src_first);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1162
        int dst_offset = ra_->reg2offset(dst_first);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1163
        if (cbuf) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1164
          emit_opcode(*cbuf, 0xFF);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1165
          encode_RegMem(*cbuf, RSI_enc, RSP_enc, 0x4, 0, src_offset, false);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1166
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1167
          emit_opcode(*cbuf, 0x8F);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1168
          encode_RegMem(*cbuf, RAX_enc, RSP_enc, 0x4, 0, dst_offset, false);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1169
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1170
#ifndef PRODUCT
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1171
        } else if (!do_size) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1172
          st->print("pushq   [rsp + #%d]\t# 64-bit mem-mem spill\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1173
                     "popq    [rsp + #%d]",
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1174
                     src_offset,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1175
                     dst_offset);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1176
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1177
        }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1178
        return
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1179
          3 + ((src_offset == 0) ? 0 : (src_offset < 0x80 ? 1 : 4)) +
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1180
          3 + ((dst_offset == 0) ? 0 : (dst_offset < 0x80 ? 1 : 4));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1181
      } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1182
        // 32-bit
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1183
        assert(!((src_first & 1) == 0 && src_first + 1 == src_second), "no transform");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1184
        assert(!((dst_first & 1) == 0 && dst_first + 1 == dst_second), "no transform");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1185
        // No pushl/popl, so:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1186
        int src_offset = ra_->reg2offset(src_first);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1187
        int dst_offset = ra_->reg2offset(dst_first);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1188
        if (cbuf) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1189
          emit_opcode(*cbuf, Assembler::REX_W);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1190
          emit_opcode(*cbuf, 0x89);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1191
          emit_opcode(*cbuf, 0x44);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1192
          emit_opcode(*cbuf, 0x24);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1193
          emit_opcode(*cbuf, 0xF8);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1194
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1195
          emit_opcode(*cbuf, 0x8B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1196
          encode_RegMem(*cbuf,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1197
                        RAX_enc,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1198
                        RSP_enc, 0x4, 0, src_offset,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1199
                        false);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1200
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1201
          emit_opcode(*cbuf, 0x89);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1202
          encode_RegMem(*cbuf,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1203
                        RAX_enc,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1204
                        RSP_enc, 0x4, 0, dst_offset,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1205
                        false);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1206
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1207
          emit_opcode(*cbuf, Assembler::REX_W);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1208
          emit_opcode(*cbuf, 0x8B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1209
          emit_opcode(*cbuf, 0x44);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1210
          emit_opcode(*cbuf, 0x24);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1211
          emit_opcode(*cbuf, 0xF8);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1212
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1213
#ifndef PRODUCT
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1214
        } else if (!do_size) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1215
          st->print("movq    [rsp - #8], rax\t# 32-bit mem-mem spill\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1216
                     "movl    rax, [rsp + #%d]\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1217
                     "movl    [rsp + #%d], rax\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1218
                     "movq    rax, [rsp - #8]",
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1219
                     src_offset,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1220
                     dst_offset);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1221
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1222
        }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1223
        return
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1224
          5 + // movq
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1225
          3 + ((src_offset == 0) ? 0 : (src_offset < 0x80 ? 1 : 4)) + // movl
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1226
          3 + ((dst_offset == 0) ? 0 : (dst_offset < 0x80 ? 1 : 4)) + // movl
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1227
          5; // movq
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1228
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1229
    } else if (dst_first_rc == rc_int) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1230
      // mem -> gpr
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1231
      if ((src_first & 1) == 0 && src_first + 1 == src_second &&
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1232
          (dst_first & 1) == 0 && dst_first + 1 == dst_second) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1233
        // 64-bit
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1234
        int offset = ra_->reg2offset(src_first);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1235
        if (cbuf) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1236
          if (Matcher::_regEncode[dst_first] < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1237
            emit_opcode(*cbuf, Assembler::REX_W);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1238
          } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1239
            emit_opcode(*cbuf, Assembler::REX_WR);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1240
          }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1241
          emit_opcode(*cbuf, 0x8B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1242
          encode_RegMem(*cbuf,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1243
                        Matcher::_regEncode[dst_first],
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1244
                        RSP_enc, 0x4, 0, offset,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1245
                        false);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1246
#ifndef PRODUCT
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1247
        } else if (!do_size) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1248
          st->print("movq    %s, [rsp + #%d]\t# spill",
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1249
                     Matcher::regName[dst_first],
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1250
                     offset);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1251
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1252
        }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1253
        return
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1254
          ((offset == 0) ? 0 : (offset < 0x80 ? 1 : 4)) + 4; // REX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1255
      } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1256
        // 32-bit
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1257
        assert(!((src_first & 1) == 0 && src_first + 1 == src_second), "no transform");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1258
        assert(!((dst_first & 1) == 0 && dst_first + 1 == dst_second), "no transform");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1259
        int offset = ra_->reg2offset(src_first);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1260
        if (cbuf) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1261
          if (Matcher::_regEncode[dst_first] >= 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1262
            emit_opcode(*cbuf, Assembler::REX_R);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1263
          }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1264
          emit_opcode(*cbuf, 0x8B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1265
          encode_RegMem(*cbuf,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1266
                        Matcher::_regEncode[dst_first],
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1267
                        RSP_enc, 0x4, 0, offset,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1268
                        false);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1269
#ifndef PRODUCT
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1270
        } else if (!do_size) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1271
          st->print("movl    %s, [rsp + #%d]\t# spill",
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1272
                     Matcher::regName[dst_first],
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1273
                     offset);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1274
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1275
        }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1276
        return
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1277
          ((offset == 0) ? 0 : (offset < 0x80 ? 1 : 4)) +
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1278
          ((Matcher::_regEncode[dst_first] < 8)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1279
           ? 3
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1280
           : 4); // REX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1281
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1282
    } else if (dst_first_rc == rc_float) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1283
      // mem-> xmm
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1284
      if ((src_first & 1) == 0 && src_first + 1 == src_second &&
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1285
          (dst_first & 1) == 0 && dst_first + 1 == dst_second) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1286
        // 64-bit
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1287
        int offset = ra_->reg2offset(src_first);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1288
        if (cbuf) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1289
          emit_opcode(*cbuf, UseXmmLoadAndClearUpper ? 0xF2 : 0x66);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1290
          if (Matcher::_regEncode[dst_first] >= 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1291
            emit_opcode(*cbuf, Assembler::REX_R);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1292
          }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1293
          emit_opcode(*cbuf, 0x0F);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1294
          emit_opcode(*cbuf, UseXmmLoadAndClearUpper ? 0x10 : 0x12);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1295
          encode_RegMem(*cbuf,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1296
                        Matcher::_regEncode[dst_first],
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1297
                        RSP_enc, 0x4, 0, offset,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1298
                        false);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1299
#ifndef PRODUCT
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1300
        } else if (!do_size) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1301
          st->print("%s  %s, [rsp + #%d]\t# spill",
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1302
                     UseXmmLoadAndClearUpper ? "movsd " : "movlpd",
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1303
                     Matcher::regName[dst_first],
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1304
                     offset);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1305
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1306
        }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1307
        return
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1308
          ((offset == 0) ? 0 : (offset < 0x80 ? 1 : 4)) +
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1309
          ((Matcher::_regEncode[dst_first] < 8)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1310
           ? 5
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1311
           : 6); // REX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1312
      } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1313
        // 32-bit
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1314
        assert(!((src_first & 1) == 0 && src_first + 1 == src_second), "no transform");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1315
        assert(!((dst_first & 1) == 0 && dst_first + 1 == dst_second), "no transform");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1316
        int offset = ra_->reg2offset(src_first);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1317
        if (cbuf) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1318
          emit_opcode(*cbuf, 0xF3);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1319
          if (Matcher::_regEncode[dst_first] >= 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1320
            emit_opcode(*cbuf, Assembler::REX_R);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1321
          }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1322
          emit_opcode(*cbuf, 0x0F);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1323
          emit_opcode(*cbuf, 0x10);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1324
          encode_RegMem(*cbuf,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1325
                        Matcher::_regEncode[dst_first],
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1326
                        RSP_enc, 0x4, 0, offset,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1327
                        false);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1328
#ifndef PRODUCT
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1329
        } else if (!do_size) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1330
          st->print("movss   %s, [rsp + #%d]\t# spill",
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1331
                     Matcher::regName[dst_first],
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1332
                     offset);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1333
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1334
        }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1335
        return
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1336
          ((offset == 0) ? 0 : (offset < 0x80 ? 1 : 4)) +
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1337
          ((Matcher::_regEncode[dst_first] < 8)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1338
           ? 5
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1339
           : 6); // REX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1340
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1341
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1342
  } else if (src_first_rc == rc_int) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1343
    // gpr ->
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1344
    if (dst_first_rc == rc_stack) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1345
      // gpr -> mem
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1346
      if ((src_first & 1) == 0 && src_first + 1 == src_second &&
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1347
          (dst_first & 1) == 0 && dst_first + 1 == dst_second) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1348
        // 64-bit
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1349
        int offset = ra_->reg2offset(dst_first);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1350
        if (cbuf) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1351
          if (Matcher::_regEncode[src_first] < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1352
            emit_opcode(*cbuf, Assembler::REX_W);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1353
          } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1354
            emit_opcode(*cbuf, Assembler::REX_WR);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1355
          }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1356
          emit_opcode(*cbuf, 0x89);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1357
          encode_RegMem(*cbuf,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1358
                        Matcher::_regEncode[src_first],
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1359
                        RSP_enc, 0x4, 0, offset,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1360
                        false);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1361
#ifndef PRODUCT
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1362
        } else if (!do_size) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1363
          st->print("movq    [rsp + #%d], %s\t# spill",
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1364
                     offset,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1365
                     Matcher::regName[src_first]);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1366
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1367
        }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1368
        return ((offset == 0) ? 0 : (offset < 0x80 ? 1 : 4)) + 4; // REX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1369
      } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1370
        // 32-bit
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1371
        assert(!((src_first & 1) == 0 && src_first + 1 == src_second), "no transform");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1372
        assert(!((dst_first & 1) == 0 && dst_first + 1 == dst_second), "no transform");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1373
        int offset = ra_->reg2offset(dst_first);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1374
        if (cbuf) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1375
          if (Matcher::_regEncode[src_first] >= 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1376
            emit_opcode(*cbuf, Assembler::REX_R);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1377
          }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1378
          emit_opcode(*cbuf, 0x89);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1379
          encode_RegMem(*cbuf,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1380
                        Matcher::_regEncode[src_first],
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1381
                        RSP_enc, 0x4, 0, offset,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1382
                        false);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1383
#ifndef PRODUCT
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1384
        } else if (!do_size) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1385
          st->print("movl    [rsp + #%d], %s\t# spill",
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1386
                     offset,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1387
                     Matcher::regName[src_first]);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1388
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1389
        }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1390
        return
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1391
          ((offset == 0) ? 0 : (offset < 0x80 ? 1 : 4)) +
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1392
          ((Matcher::_regEncode[src_first] < 8)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1393
           ? 3
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1394
           : 4); // REX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1395
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1396
    } else if (dst_first_rc == rc_int) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1397
      // gpr -> gpr
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1398
      if ((src_first & 1) == 0 && src_first + 1 == src_second &&
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1399
          (dst_first & 1) == 0 && dst_first + 1 == dst_second) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1400
        // 64-bit
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1401
        if (cbuf) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1402
          if (Matcher::_regEncode[dst_first] < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1403
            if (Matcher::_regEncode[src_first] < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1404
              emit_opcode(*cbuf, Assembler::REX_W);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1405
            } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1406
              emit_opcode(*cbuf, Assembler::REX_WB);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1407
            }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1408
          } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1409
            if (Matcher::_regEncode[src_first] < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1410
              emit_opcode(*cbuf, Assembler::REX_WR);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1411
            } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1412
              emit_opcode(*cbuf, Assembler::REX_WRB);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1413
            }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1414
          }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1415
          emit_opcode(*cbuf, 0x8B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1416
          emit_rm(*cbuf, 0x3,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1417
                  Matcher::_regEncode[dst_first] & 7,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1418
                  Matcher::_regEncode[src_first] & 7);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1419
#ifndef PRODUCT
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1420
        } else if (!do_size) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1421
          st->print("movq    %s, %s\t# spill",
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1422
                     Matcher::regName[dst_first],
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1423
                     Matcher::regName[src_first]);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1424
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1425
        }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1426
        return 3; // REX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1427
      } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1428
        // 32-bit
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1429
        assert(!((src_first & 1) == 0 && src_first + 1 == src_second), "no transform");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1430
        assert(!((dst_first & 1) == 0 && dst_first + 1 == dst_second), "no transform");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1431
        if (cbuf) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1432
          if (Matcher::_regEncode[dst_first] < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1433
            if (Matcher::_regEncode[src_first] >= 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1434
              emit_opcode(*cbuf, Assembler::REX_B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1435
            }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1436
          } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1437
            if (Matcher::_regEncode[src_first] < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1438
              emit_opcode(*cbuf, Assembler::REX_R);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1439
            } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1440
              emit_opcode(*cbuf, Assembler::REX_RB);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1441
            }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1442
          }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1443
          emit_opcode(*cbuf, 0x8B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1444
          emit_rm(*cbuf, 0x3,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1445
                  Matcher::_regEncode[dst_first] & 7,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1446
                  Matcher::_regEncode[src_first] & 7);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1447
#ifndef PRODUCT
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1448
        } else if (!do_size) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1449
          st->print("movl    %s, %s\t# spill",
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1450
                     Matcher::regName[dst_first],
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1451
                     Matcher::regName[src_first]);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1452
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1453
        }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1454
        return
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1455
          (Matcher::_regEncode[src_first] < 8 && Matcher::_regEncode[dst_first] < 8)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1456
          ? 2
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1457
          : 3; // REX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1458
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1459
    } else if (dst_first_rc == rc_float) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1460
      // gpr -> xmm
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1461
      if ((src_first & 1) == 0 && src_first + 1 == src_second &&
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1462
          (dst_first & 1) == 0 && dst_first + 1 == dst_second) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1463
        // 64-bit
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1464
        if (cbuf) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1465
          emit_opcode(*cbuf, 0x66);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1466
          if (Matcher::_regEncode[dst_first] < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1467
            if (Matcher::_regEncode[src_first] < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1468
              emit_opcode(*cbuf, Assembler::REX_W);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1469
            } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1470
              emit_opcode(*cbuf, Assembler::REX_WB);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1471
            }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1472
          } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1473
            if (Matcher::_regEncode[src_first] < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1474
              emit_opcode(*cbuf, Assembler::REX_WR);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1475
            } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1476
              emit_opcode(*cbuf, Assembler::REX_WRB);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1477
            }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1478
          }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1479
          emit_opcode(*cbuf, 0x0F);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1480
          emit_opcode(*cbuf, 0x6E);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1481
          emit_rm(*cbuf, 0x3,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1482
                  Matcher::_regEncode[dst_first] & 7,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1483
                  Matcher::_regEncode[src_first] & 7);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1484
#ifndef PRODUCT
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1485
        } else if (!do_size) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1486
          st->print("movdq   %s, %s\t# spill",
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1487
                     Matcher::regName[dst_first],
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1488
                     Matcher::regName[src_first]);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1489
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1490
        }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1491
        return 5; // REX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1492
      } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1493
        // 32-bit
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1494
        assert(!((src_first & 1) == 0 && src_first + 1 == src_second), "no transform");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1495
        assert(!((dst_first & 1) == 0 && dst_first + 1 == dst_second), "no transform");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1496
        if (cbuf) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1497
          emit_opcode(*cbuf, 0x66);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1498
          if (Matcher::_regEncode[dst_first] < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1499
            if (Matcher::_regEncode[src_first] >= 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1500
              emit_opcode(*cbuf, Assembler::REX_B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1501
            }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1502
          } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1503
            if (Matcher::_regEncode[src_first] < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1504
              emit_opcode(*cbuf, Assembler::REX_R);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1505
            } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1506
              emit_opcode(*cbuf, Assembler::REX_RB);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1507
            }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1508
          }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1509
          emit_opcode(*cbuf, 0x0F);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1510
          emit_opcode(*cbuf, 0x6E);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1511
          emit_rm(*cbuf, 0x3,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1512
                  Matcher::_regEncode[dst_first] & 7,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1513
                  Matcher::_regEncode[src_first] & 7);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1514
#ifndef PRODUCT
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1515
        } else if (!do_size) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1516
          st->print("movdl   %s, %s\t# spill",
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1517
                     Matcher::regName[dst_first],
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1518
                     Matcher::regName[src_first]);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1519
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1520
        }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1521
        return
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1522
          (Matcher::_regEncode[src_first] < 8 && Matcher::_regEncode[dst_first] < 8)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1523
          ? 4
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1524
          : 5; // REX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1525
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1526
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1527
  } else if (src_first_rc == rc_float) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1528
    // xmm ->
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1529
    if (dst_first_rc == rc_stack) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1530
      // xmm -> mem
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1531
      if ((src_first & 1) == 0 && src_first + 1 == src_second &&
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1532
          (dst_first & 1) == 0 && dst_first + 1 == dst_second) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1533
        // 64-bit
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1534
        int offset = ra_->reg2offset(dst_first);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1535
        if (cbuf) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1536
          emit_opcode(*cbuf, 0xF2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1537
          if (Matcher::_regEncode[src_first] >= 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1538
              emit_opcode(*cbuf, Assembler::REX_R);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1539
          }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1540
          emit_opcode(*cbuf, 0x0F);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1541
          emit_opcode(*cbuf, 0x11);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1542
          encode_RegMem(*cbuf,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1543
                        Matcher::_regEncode[src_first],
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1544
                        RSP_enc, 0x4, 0, offset,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1545
                        false);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1546
#ifndef PRODUCT
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1547
        } else if (!do_size) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1548
          st->print("movsd   [rsp + #%d], %s\t# spill",
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1549
                     offset,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1550
                     Matcher::regName[src_first]);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1551
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1552
        }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1553
        return
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1554
          ((offset == 0) ? 0 : (offset < 0x80 ? 1 : 4)) +
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1555
          ((Matcher::_regEncode[src_first] < 8)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1556
           ? 5
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1557
           : 6); // REX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1558
      } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1559
        // 32-bit
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1560
        assert(!((src_first & 1) == 0 && src_first + 1 == src_second), "no transform");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1561
        assert(!((dst_first & 1) == 0 && dst_first + 1 == dst_second), "no transform");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1562
        int offset = ra_->reg2offset(dst_first);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1563
        if (cbuf) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1564
          emit_opcode(*cbuf, 0xF3);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1565
          if (Matcher::_regEncode[src_first] >= 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1566
              emit_opcode(*cbuf, Assembler::REX_R);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1567
          }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1568
          emit_opcode(*cbuf, 0x0F);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1569
          emit_opcode(*cbuf, 0x11);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1570
          encode_RegMem(*cbuf,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1571
                        Matcher::_regEncode[src_first],
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1572
                        RSP_enc, 0x4, 0, offset,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1573
                        false);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1574
#ifndef PRODUCT
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1575
        } else if (!do_size) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1576
          st->print("movss   [rsp + #%d], %s\t# spill",
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1577
                     offset,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1578
                     Matcher::regName[src_first]);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1579
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1580
        }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1581
        return
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1582
          ((offset == 0) ? 0 : (offset < 0x80 ? 1 : 4)) +
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1583
          ((Matcher::_regEncode[src_first] < 8)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1584
           ? 5
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1585
           : 6); // REX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1586
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1587
    } else if (dst_first_rc == rc_int) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1588
      // xmm -> gpr
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1589
      if ((src_first & 1) == 0 && src_first + 1 == src_second &&
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1590
          (dst_first & 1) == 0 && dst_first + 1 == dst_second) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1591
        // 64-bit
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1592
        if (cbuf) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1593
          emit_opcode(*cbuf, 0x66);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1594
          if (Matcher::_regEncode[dst_first] < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1595
            if (Matcher::_regEncode[src_first] < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1596
              emit_opcode(*cbuf, Assembler::REX_W);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1597
            } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1598
              emit_opcode(*cbuf, Assembler::REX_WR); // attention!
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1599
            }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1600
          } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1601
            if (Matcher::_regEncode[src_first] < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1602
              emit_opcode(*cbuf, Assembler::REX_WB); // attention!
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1603
            } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1604
              emit_opcode(*cbuf, Assembler::REX_WRB);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1605
            }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1606
          }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1607
          emit_opcode(*cbuf, 0x0F);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1608
          emit_opcode(*cbuf, 0x7E);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1609
          emit_rm(*cbuf, 0x3,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1610
                  Matcher::_regEncode[dst_first] & 7,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1611
                  Matcher::_regEncode[src_first] & 7);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1612
#ifndef PRODUCT
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1613
        } else if (!do_size) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1614
          st->print("movdq   %s, %s\t# spill",
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1615
                     Matcher::regName[dst_first],
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1616
                     Matcher::regName[src_first]);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1617
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1618
        }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1619
        return 5; // REX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1620
      } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1621
        // 32-bit
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1622
        assert(!((src_first & 1) == 0 && src_first + 1 == src_second), "no transform");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1623
        assert(!((dst_first & 1) == 0 && dst_first + 1 == dst_second), "no transform");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1624
        if (cbuf) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1625
          emit_opcode(*cbuf, 0x66);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1626
          if (Matcher::_regEncode[dst_first] < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1627
            if (Matcher::_regEncode[src_first] >= 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1628
              emit_opcode(*cbuf, Assembler::REX_R); // attention!
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1629
            }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1630
          } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1631
            if (Matcher::_regEncode[src_first] < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1632
              emit_opcode(*cbuf, Assembler::REX_B); // attention!
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1633
            } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1634
              emit_opcode(*cbuf, Assembler::REX_RB);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1635
            }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1636
          }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1637
          emit_opcode(*cbuf, 0x0F);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1638
          emit_opcode(*cbuf, 0x7E);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1639
          emit_rm(*cbuf, 0x3,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1640
                  Matcher::_regEncode[dst_first] & 7,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1641
                  Matcher::_regEncode[src_first] & 7);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1642
#ifndef PRODUCT
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1643
        } else if (!do_size) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1644
          st->print("movdl   %s, %s\t# spill",
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1645
                     Matcher::regName[dst_first],
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1646
                     Matcher::regName[src_first]);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1647
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1648
        }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1649
        return
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1650
          (Matcher::_regEncode[src_first] < 8 && Matcher::_regEncode[dst_first] < 8)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1651
          ? 4
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1652
          : 5; // REX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1653
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1654
    } else if (dst_first_rc == rc_float) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1655
      // xmm -> xmm
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1656
      if ((src_first & 1) == 0 && src_first + 1 == src_second &&
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1657
          (dst_first & 1) == 0 && dst_first + 1 == dst_second) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1658
        // 64-bit
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1659
        if (cbuf) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1660
          emit_opcode(*cbuf, UseXmmRegToRegMoveAll ? 0x66 : 0xF2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1661
          if (Matcher::_regEncode[dst_first] < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1662
            if (Matcher::_regEncode[src_first] >= 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1663
              emit_opcode(*cbuf, Assembler::REX_B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1664
            }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1665
          } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1666
            if (Matcher::_regEncode[src_first] < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1667
              emit_opcode(*cbuf, Assembler::REX_R);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1668
            } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1669
              emit_opcode(*cbuf, Assembler::REX_RB);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1670
            }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1671
          }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1672
          emit_opcode(*cbuf, 0x0F);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1673
          emit_opcode(*cbuf, UseXmmRegToRegMoveAll ? 0x28 : 0x10);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1674
          emit_rm(*cbuf, 0x3,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1675
                  Matcher::_regEncode[dst_first] & 7,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1676
                  Matcher::_regEncode[src_first] & 7);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1677
#ifndef PRODUCT
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1678
        } else if (!do_size) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1679
          st->print("%s  %s, %s\t# spill",
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1680
                     UseXmmRegToRegMoveAll ? "movapd" : "movsd ",
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1681
                     Matcher::regName[dst_first],
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1682
                     Matcher::regName[src_first]);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1683
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1684
        }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1685
        return
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1686
          (Matcher::_regEncode[src_first] < 8 && Matcher::_regEncode[dst_first] < 8)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1687
          ? 4
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1688
          : 5; // REX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1689
      } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1690
        // 32-bit
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1691
        assert(!((src_first & 1) == 0 && src_first + 1 == src_second), "no transform");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1692
        assert(!((dst_first & 1) == 0 && dst_first + 1 == dst_second), "no transform");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1693
        if (cbuf) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1694
          if (!UseXmmRegToRegMoveAll)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1695
            emit_opcode(*cbuf, 0xF3);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1696
          if (Matcher::_regEncode[dst_first] < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1697
            if (Matcher::_regEncode[src_first] >= 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1698
              emit_opcode(*cbuf, Assembler::REX_B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1699
            }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1700
          } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1701
            if (Matcher::_regEncode[src_first] < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1702
              emit_opcode(*cbuf, Assembler::REX_R);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1703
            } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1704
              emit_opcode(*cbuf, Assembler::REX_RB);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1705
            }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1706
          }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1707
          emit_opcode(*cbuf, 0x0F);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1708
          emit_opcode(*cbuf, UseXmmRegToRegMoveAll ? 0x28 : 0x10);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1709
          emit_rm(*cbuf, 0x3,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1710
                  Matcher::_regEncode[dst_first] & 7,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1711
                  Matcher::_regEncode[src_first] & 7);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1712
#ifndef PRODUCT
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1713
        } else if (!do_size) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1714
          st->print("%s  %s, %s\t# spill",
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1715
                     UseXmmRegToRegMoveAll ? "movaps" : "movss ",
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1716
                     Matcher::regName[dst_first],
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1717
                     Matcher::regName[src_first]);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1718
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1719
        }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1720
        return
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1721
          (Matcher::_regEncode[src_first] < 8 && Matcher::_regEncode[dst_first] < 8)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1722
          ? (UseXmmRegToRegMoveAll ? 3 : 4)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1723
          : (UseXmmRegToRegMoveAll ? 4 : 5); // REX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1724
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1725
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1726
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1727
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1728
  assert(0," foo ");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1729
  Unimplemented();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1730
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1731
  return 0;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1732
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1733
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1734
#ifndef PRODUCT
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1735
void MachSpillCopyNode::format(PhaseRegAlloc *ra_, outputStream* st) const
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1736
{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1737
  implementation(NULL, ra_, false, st);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1738
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1739
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1740
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1741
void MachSpillCopyNode::emit(CodeBuffer &cbuf, PhaseRegAlloc *ra_) const
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1742
{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1743
  implementation(&cbuf, ra_, false, NULL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1744
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1745
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1746
uint MachSpillCopyNode::size(PhaseRegAlloc *ra_) const
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1747
{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1748
  return implementation(NULL, ra_, true, NULL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1749
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1750
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1751
//=============================================================================
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1752
#ifndef PRODUCT
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1753
void MachNopNode::format(PhaseRegAlloc*, outputStream* st) const
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1754
{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1755
  st->print("nop \t# %d bytes pad for loops and calls", _count);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1756
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1757
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1758
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1759
void MachNopNode::emit(CodeBuffer &cbuf, PhaseRegAlloc*) const
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1760
{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1761
  MacroAssembler _masm(&cbuf);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1762
  __ nop(_count);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1763
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1764
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1765
uint MachNopNode::size(PhaseRegAlloc*) const
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1766
{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1767
  return _count;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1768
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1769
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1770
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1771
//=============================================================================
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1772
#ifndef PRODUCT
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1773
void BoxLockNode::format(PhaseRegAlloc* ra_, outputStream* st) const
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1774
{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1775
  int offset = ra_->reg2offset(in_RegMask(0).find_first_elem());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1776
  int reg = ra_->get_reg_first(this);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1777
  st->print("leaq    %s, [rsp + #%d]\t# box lock",
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1778
            Matcher::regName[reg], offset);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1779
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1780
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1781
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1782
void BoxLockNode::emit(CodeBuffer& cbuf, PhaseRegAlloc* ra_) const
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1783
{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1784
  int offset = ra_->reg2offset(in_RegMask(0).find_first_elem());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1785
  int reg = ra_->get_encode(this);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1786
  if (offset >= 0x80) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1787
    emit_opcode(cbuf, reg < 8 ? Assembler::REX_W : Assembler::REX_WR);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1788
    emit_opcode(cbuf, 0x8D); // LEA  reg,[SP+offset]
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1789
    emit_rm(cbuf, 0x2, reg & 7, 0x04);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1790
    emit_rm(cbuf, 0x0, 0x04, RSP_enc);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1791
    emit_d32(cbuf, offset);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1792
  } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1793
    emit_opcode(cbuf, reg < 8 ? Assembler::REX_W : Assembler::REX_WR);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1794
    emit_opcode(cbuf, 0x8D); // LEA  reg,[SP+offset]
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1795
    emit_rm(cbuf, 0x1, reg & 7, 0x04);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1796
    emit_rm(cbuf, 0x0, 0x04, RSP_enc);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1797
    emit_d8(cbuf, offset);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1798
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1799
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1800
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1801
uint BoxLockNode::size(PhaseRegAlloc *ra_) const
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1802
{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1803
  int offset = ra_->reg2offset(in_RegMask(0).find_first_elem());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1804
  return (offset < 0x80) ? 5 : 8; // REX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1805
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1806
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1807
//=============================================================================
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1808
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1809
// emit call stub, compiled java to interpreter
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1810
void emit_java_to_interp(CodeBuffer& cbuf)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1811
{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1812
  // Stub is fixed up when the corresponding call is converted from
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1813
  // calling compiled code to calling interpreted code.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1814
  // movq rbx, 0
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1815
  // jmp -5 # to self
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1816
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1817
  address mark = cbuf.inst_mark();  // get mark within main instrs section
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1818
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1819
  // Note that the code buffer's inst_mark is always relative to insts.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1820
  // That's why we must use the macroassembler to generate a stub.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1821
  MacroAssembler _masm(&cbuf);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1822
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1823
  address base =
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1824
  __ start_a_stub(Compile::MAX_stubs_size);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1825
  if (base == NULL)  return;  // CodeBuffer::expand failed
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1826
  // static stub relocation stores the instruction address of the call
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1827
  __ relocate(static_stub_Relocation::spec(mark), RELOC_IMM64);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1828
  // static stub relocation also tags the methodOop in the code-stream.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1829
  __ movoop(rbx, (jobject) NULL);  // method is zapped till fixup time
1066
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  1830
  // This is recognized as unresolved by relocs/nativeinst/ic code
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1831
  __ jump(RuntimeAddress(__ pc()));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1832
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1833
  // Update current stubs pointer and restore code_end.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1834
  __ end_a_stub();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1835
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1836
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1837
// size of call stub, compiled java to interpretor
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1838
uint size_java_to_interp()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1839
{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1840
  return 15;  // movq (1+1+8); jmp (1+4)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1841
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1842
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1843
// relocation entries for call stub, compiled java to interpretor
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1844
uint reloc_java_to_interp()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1845
{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1846
  return 4; // 3 in emit_java_to_interp + 1 in Java_Static_Call
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1847
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1848
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1849
//=============================================================================
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1850
#ifndef PRODUCT
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1851
void MachUEPNode::format(PhaseRegAlloc* ra_, outputStream* st) const
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1852
{
360
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  1853
  if (UseCompressedOops) {
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  1854
    st->print_cr("movl    rscratch1, [j_rarg0 + oopDesc::klass_offset_in_bytes() #%d]\t", oopDesc::klass_offset_in_bytes());
2254
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  1855
    if (Universe::narrow_oop_shift() != 0) {
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  1856
      st->print_cr("leaq    rscratch1, [r12_heapbase, r, Address::times_8, 0]");
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  1857
    }
360
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  1858
    st->print_cr("cmpq    rax, rscratch1\t # Inline cache check");
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  1859
  } else {
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  1860
    st->print_cr("cmpq    rax, [j_rarg0 + oopDesc::klass_offset_in_bytes() #%d]\t"
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  1861
                 "# Inline cache check", oopDesc::klass_offset_in_bytes());
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  1862
  }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1863
  st->print_cr("\tjne     SharedRuntime::_ic_miss_stub");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1864
  st->print_cr("\tnop");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1865
  if (!OptoBreakpoint) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1866
    st->print_cr("\tnop");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1867
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1868
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1869
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1870
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1871
void MachUEPNode::emit(CodeBuffer& cbuf, PhaseRegAlloc* ra_) const
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1872
{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1873
  MacroAssembler masm(&cbuf);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1874
#ifdef ASSERT
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1875
  uint code_size = cbuf.code_size();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1876
#endif
360
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  1877
  if (UseCompressedOops) {
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  1878
    masm.load_klass(rscratch1, j_rarg0);
1066
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  1879
    masm.cmpptr(rax, rscratch1);
360
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  1880
  } else {
1066
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  1881
    masm.cmpptr(rax, Address(j_rarg0, oopDesc::klass_offset_in_bytes()));
360
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  1882
  }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1883
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1884
  masm.jump_cc(Assembler::notEqual, RuntimeAddress(SharedRuntime::get_ic_miss_stub()));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1885
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1886
  /* WARNING these NOPs are critical so that verified entry point is properly
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1887
     aligned for patching by NativeJump::patch_verified_entry() */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1888
  int nops_cnt = 1;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1889
  if (!OptoBreakpoint) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1890
    // Leave space for int3
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1891
     nops_cnt += 1;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1892
  }
360
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  1893
  if (UseCompressedOops) {
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  1894
    // ??? divisible by 4 is aligned?
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  1895
    nops_cnt += 1;
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  1896
  }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1897
  masm.nop(nops_cnt);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1898
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1899
  assert(cbuf.code_size() - code_size == size(ra_),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1900
         "checking code size of inline cache node");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1901
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1902
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1903
uint MachUEPNode::size(PhaseRegAlloc* ra_) const
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1904
{
360
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  1905
  if (UseCompressedOops) {
2254
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  1906
    if (Universe::narrow_oop_shift() == 0) {
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  1907
      return OptoBreakpoint ? 15 : 16;
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  1908
    } else {
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  1909
      return OptoBreakpoint ? 19 : 20;
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  1910
    }
360
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  1911
  } else {
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  1912
    return OptoBreakpoint ? 11 : 12;
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  1913
  }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1914
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1915
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1916
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1917
//=============================================================================
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1918
uint size_exception_handler()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1919
{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1920
  // NativeCall instruction size is the same as NativeJump.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1921
  // Note that this value is also credited (in output.cpp) to
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1922
  // the size of the code section.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1923
  return NativeJump::instruction_size;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1924
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1925
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1926
// Emit exception handler code.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1927
int emit_exception_handler(CodeBuffer& cbuf)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1928
{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1929
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1930
  // Note that the code buffer's inst_mark is always relative to insts.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1931
  // That's why we must use the macroassembler to generate a handler.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1932
  MacroAssembler _masm(&cbuf);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1933
  address base =
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1934
  __ start_a_stub(size_exception_handler());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1935
  if (base == NULL)  return 0;  // CodeBuffer::expand failed
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1936
  int offset = __ offset();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1937
  __ jump(RuntimeAddress(OptoRuntime::exception_blob()->instructions_begin()));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1938
  assert(__ offset() - offset <= (int) size_exception_handler(), "overflow");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1939
  __ end_a_stub();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1940
  return offset;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1941
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1942
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1943
uint size_deopt_handler()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1944
{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1945
  // three 5 byte instructions
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1946
  return 15;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1947
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1948
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1949
// Emit deopt handler code.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1950
int emit_deopt_handler(CodeBuffer& cbuf)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1951
{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1952
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1953
  // Note that the code buffer's inst_mark is always relative to insts.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1954
  // That's why we must use the macroassembler to generate a handler.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1955
  MacroAssembler _masm(&cbuf);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1956
  address base =
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1957
  __ start_a_stub(size_deopt_handler());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1958
  if (base == NULL)  return 0;  // CodeBuffer::expand failed
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1959
  int offset = __ offset();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1960
  address the_pc = (address) __ pc();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1961
  Label next;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1962
  // push a "the_pc" on the stack without destroying any registers
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1963
  // as they all may be live.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1964
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1965
  // push address of "next"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1966
  __ call(next, relocInfo::none); // reloc none is fine since it is a disp32
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1967
  __ bind(next);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1968
  // adjust it so it matches "the_pc"
1066
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  1969
  __ subptr(Address(rsp, 0), __ offset() - offset);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1970
  __ jump(RuntimeAddress(SharedRuntime::deopt_blob()->unpack()));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1971
  assert(__ offset() - offset <= (int) size_deopt_handler(), "overflow");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1972
  __ end_a_stub();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1973
  return offset;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1974
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1975
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1976
static void emit_double_constant(CodeBuffer& cbuf, double x) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1977
  int mark = cbuf.insts()->mark_off();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1978
  MacroAssembler _masm(&cbuf);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1979
  address double_address = __ double_constant(x);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1980
  cbuf.insts()->set_mark_off(mark);  // preserve mark across masm shift
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1981
  emit_d32_reloc(cbuf,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1982
                 (int) (double_address - cbuf.code_end() - 4),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1983
                 internal_word_Relocation::spec(double_address),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1984
                 RELOC_DISP32);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1985
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1986
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1987
static void emit_float_constant(CodeBuffer& cbuf, float x) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1988
  int mark = cbuf.insts()->mark_off();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1989
  MacroAssembler _masm(&cbuf);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1990
  address float_address = __ float_constant(x);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1991
  cbuf.insts()->set_mark_off(mark);  // preserve mark across masm shift
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1992
  emit_d32_reloc(cbuf,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1993
                 (int) (float_address - cbuf.code_end() - 4),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1994
                 internal_word_Relocation::spec(float_address),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1995
                 RELOC_DISP32);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1996
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1997
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1998
2862
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  1999
const bool Matcher::match_rule_supported(int opcode) {
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  2000
  if (!has_match_rule(opcode))
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  2001
    return false;
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  2002
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  2003
  return true;  // Per default match rules are supported.
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  2004
}
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  2005
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2006
int Matcher::regnum_to_fpu_offset(int regnum)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2007
{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2008
  return regnum - 32; // The FP registers are in the second chunk
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2009
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2010
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2011
// This is UltraSparc specific, true just means we have fast l2f conversion
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2012
const bool Matcher::convL2FSupported(void) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2013
  return true;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2014
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2015
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2016
// Vector width in bytes
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2017
const uint Matcher::vector_width_in_bytes(void) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2018
  return 8;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2019
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2020
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2021
// Vector ideal reg
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2022
const uint Matcher::vector_ideal_reg(void) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2023
  return Op_RegD;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2024
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2025
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2026
// Is this branch offset short enough that a short branch can be used?
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2027
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2028
// NOTE: If the platform does not provide any short branch variants, then
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2029
//       this method should return false for offset 0.
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  2030
bool Matcher::is_short_branch_offset(int rule, int offset) {
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  2031
  // 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
  2032
  // 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
  2033
  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
  2034
    return (-126 <= offset && offset <= 125);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  2035
  return (-128 <= offset && offset <= 127);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2036
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2037
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2038
const bool Matcher::isSimpleConstant64(jlong value) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2039
  // Will one (StoreL ConL) be cheaper than two (StoreI ConI)?.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2040
  //return value == (int) value;  // Cf. storeImmL and immL32.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2041
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2042
  // Probably always true, even if a temp register is required.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2043
  return true;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2044
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2045
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2046
// The ecx parameter to rep stosq for the ClearArray node is in words.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2047
const bool Matcher::init_array_count_is_in_bytes = false;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2048
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2049
// Threshold size for cleararray.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2050
const int Matcher::init_array_short_size = 8 * BytesPerLong;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2051
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2052
// Should the Matcher clone shifts on addressing modes, expecting them
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2053
// to be subsumed into complex addressing expressions or compute them
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2054
// into registers?  True for Intel but false for most RISCs
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2055
const bool Matcher::clone_shift_expressions = true;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2056
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2057
// Is it better to copy float constants, or load them directly from
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2058
// memory?  Intel can load a float constant from a direct address,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2059
// requiring no extra registers.  Most RISCs will have to materialize
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2060
// an address into a register first, so they would do better to copy
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2061
// the constant from stack.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2062
const bool Matcher::rematerialize_float_constants = true; // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2063
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2064
// If CPU can load and store mis-aligned doubles directly then no
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2065
// fixup is needed.  Else we split the double into 2 integer pieces
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2066
// and move it piece-by-piece.  Only happens when passing doubles into
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2067
// C code as the Java calling convention forces doubles to be aligned.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2068
const bool Matcher::misaligned_doubles_ok = true;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2069
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2070
// No-op on amd64
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2071
void Matcher::pd_implicit_null_fixup(MachNode *node, uint idx) {}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2072
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2073
// Advertise here if the CPU requires explicit rounding operations to
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2074
// implement the UseStrictFP mode.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2075
const bool Matcher::strict_fp_requires_explicit_rounding = true;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2076
5025
05adc9b8f96a 6910664: C2: java/util/Arrays/Sorting.java fails with DeoptimizeALot flag
kvn
parents: 4566
diff changeset
  2077
// 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: 4566
diff changeset
  2078
// On x64 it is stored without convertion so we can use normal access.
05adc9b8f96a 6910664: C2: java/util/Arrays/Sorting.java fails with DeoptimizeALot flag
kvn
parents: 4566
diff changeset
  2079
bool Matcher::float_in_double() { return false; }
05adc9b8f96a 6910664: C2: java/util/Arrays/Sorting.java fails with DeoptimizeALot flag
kvn
parents: 4566
diff changeset
  2080
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2081
// Do ints take an entire long register or just half?
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2082
const bool Matcher::int_in_long = true;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2083
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2084
// Return whether or not this register is ever used as an argument.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2085
// This function is used on startup to build the trampoline stubs in
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2086
// generateOptoStub.  Registers not mentioned will be killed by the VM
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2087
// call in the trampoline, and arguments in those registers not be
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2088
// available to the callee.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2089
bool Matcher::can_be_java_arg(int reg)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2090
{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2091
  return
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2092
    reg ==  RDI_num || reg ==  RDI_H_num ||
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2093
    reg ==  RSI_num || reg ==  RSI_H_num ||
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2094
    reg ==  RDX_num || reg ==  RDX_H_num ||
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2095
    reg ==  RCX_num || reg ==  RCX_H_num ||
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2096
    reg ==   R8_num || reg ==   R8_H_num ||
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2097
    reg ==   R9_num || reg ==   R9_H_num ||
360
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  2098
    reg ==  R12_num || reg ==  R12_H_num ||
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2099
    reg == XMM0_num || reg == XMM0_H_num ||
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2100
    reg == XMM1_num || reg == XMM1_H_num ||
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2101
    reg == XMM2_num || reg == XMM2_H_num ||
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2102
    reg == XMM3_num || reg == XMM3_H_num ||
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2103
    reg == XMM4_num || reg == XMM4_H_num ||
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2104
    reg == XMM5_num || reg == XMM5_H_num ||
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2105
    reg == XMM6_num || reg == XMM6_H_num ||
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2106
    reg == XMM7_num || reg == XMM7_H_num;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2107
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2108
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2109
bool Matcher::is_spillable_arg(int reg)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2110
{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2111
  return can_be_java_arg(reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2112
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2113
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2114
// Register for DIVI projection of divmodI
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2115
RegMask Matcher::divI_proj_mask() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2116
  return INT_RAX_REG_mask;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2117
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2118
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2119
// Register for MODI projection of divmodI
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2120
RegMask Matcher::modI_proj_mask() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2121
  return INT_RDX_REG_mask;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2122
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2123
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2124
// Register for DIVL projection of divmodL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2125
RegMask Matcher::divL_proj_mask() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2126
  return LONG_RAX_REG_mask;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2127
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2128
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2129
// Register for MODL projection of divmodL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2130
RegMask Matcher::modL_proj_mask() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2131
  return LONG_RDX_REG_mask;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2132
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2133
4566
b363f6ef4068 6829187: compiler optimizations required for JSR 292
twisti
parents: 3908
diff changeset
  2134
const RegMask Matcher::method_handle_invoke_SP_save_mask() {
b363f6ef4068 6829187: compiler optimizations required for JSR 292
twisti
parents: 3908
diff changeset
  2135
  return PTR_RBP_REG_mask;
b363f6ef4068 6829187: compiler optimizations required for JSR 292
twisti
parents: 3908
diff changeset
  2136
}
b363f6ef4068 6829187: compiler optimizations required for JSR 292
twisti
parents: 3908
diff changeset
  2137
360
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  2138
static Address build_address(int b, int i, int s, int d) {
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  2139
  Register index = as_Register(i);
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  2140
  Address::ScaleFactor scale = (Address::ScaleFactor)s;
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  2141
  if (index == rsp) {
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  2142
    index = noreg;
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  2143
    scale = Address::no_scale;
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  2144
  }
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  2145
  Address addr(as_Register(b), index, scale, d);
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  2146
  return addr;
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  2147
}
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  2148
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2149
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2150
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2151
//----------ENCODING BLOCK-----------------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2152
// This block specifies the encoding classes used by the compiler to
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2153
// output byte streams.  Encoding classes are parameterized macros
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2154
// used by Machine Instruction Nodes in order to generate the bit
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2155
// encoding of the instruction.  Operands specify their base encoding
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2156
// interface with the interface keyword.  There are currently
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2157
// supported four interfaces, REG_INTER, CONST_INTER, MEMORY_INTER, &
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2158
// COND_INTER.  REG_INTER causes an operand to generate a function
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2159
// which returns its register number when queried.  CONST_INTER causes
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2160
// an operand to generate a function which returns the value of the
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2161
// constant when queried.  MEMORY_INTER causes an operand to generate
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2162
// four functions which return the Base Register, the Index Register,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2163
// the Scale Value, and the Offset Value of the operand when queried.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2164
// COND_INTER causes an operand to generate six functions which return
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2165
// the encoding code (ie - encoding bits for the instruction)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2166
// associated with each basic boolean condition for a conditional
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2167
// instruction.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2168
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2169
// Instructions specify two basic values for encoding.  Again, a
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2170
// function is available to check if the constant displacement is an
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2171
// oop. They use the ins_encode keyword to specify their encoding
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2172
// classes (which must be a sequence of enc_class names, and their
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2173
// parameters, specified in the encoding block), and they use the
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2174
// opcode keyword to specify, in order, their primary, secondary, and
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2175
// tertiary opcode.  Only the opcode sections which a particular
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2176
// instruction needs for encoding need to be specified.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2177
encode %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2178
  // Build emit functions for each basic byte or larger field in the
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2179
  // intel encoding scheme (opcode, rm, sib, immediate), and call them
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2180
  // from C++ code in the enc_class source block.  Emit functions will
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2181
  // live in the main source block for now.  In future, we can
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2182
  // generalize this by adding a syntax that specifies the sizes of
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2183
  // fields in an order, so that the adlc can build the emit functions
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2184
  // automagically
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2185
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2186
  // Emit primary opcode
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2187
  enc_class OpcP
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2188
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2189
    emit_opcode(cbuf, $primary);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2190
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2191
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2192
  // Emit secondary opcode
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2193
  enc_class OpcS
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2194
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2195
    emit_opcode(cbuf, $secondary);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2196
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2197
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2198
  // Emit tertiary opcode
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2199
  enc_class OpcT
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2200
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2201
    emit_opcode(cbuf, $tertiary);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2202
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2203
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2204
  // Emit opcode directly
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2205
  enc_class Opcode(immI d8)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2206
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2207
    emit_opcode(cbuf, $d8$$constant);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2208
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2209
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2210
  // Emit size prefix
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2211
  enc_class SizePrefix
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2212
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2213
    emit_opcode(cbuf, 0x66);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2214
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2215
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2216
  enc_class reg(rRegI reg)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2217
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2218
    emit_rm(cbuf, 0x3, 0, $reg$$reg & 7);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2219
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2220
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2221
  enc_class reg_reg(rRegI dst, rRegI src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2222
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2223
    emit_rm(cbuf, 0x3, $dst$$reg & 7, $src$$reg & 7);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2224
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2225
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2226
  enc_class opc_reg_reg(immI opcode, rRegI dst, rRegI src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2227
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2228
    emit_opcode(cbuf, $opcode$$constant);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2229
    emit_rm(cbuf, 0x3, $dst$$reg & 7, $src$$reg & 7);
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 cmpfp_fixup()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2233
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2234
    // jnp,s exit
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2235
    emit_opcode(cbuf, 0x7B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2236
    emit_d8(cbuf, 0x0A);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2237
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2238
    // pushfq
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2239
    emit_opcode(cbuf, 0x9C);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2240
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2241
    // andq $0xffffff2b, (%rsp)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2242
    emit_opcode(cbuf, Assembler::REX_W);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2243
    emit_opcode(cbuf, 0x81);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2244
    emit_opcode(cbuf, 0x24);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2245
    emit_opcode(cbuf, 0x24);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2246
    emit_d32(cbuf, 0xffffff2b);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2247
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2248
    // popfq
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2249
    emit_opcode(cbuf, 0x9D);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2250
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2251
    // nop (target for branch to avoid branch to branch)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2252
    emit_opcode(cbuf, 0x90);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2253
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2254
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2255
  enc_class cmpfp3(rRegI dst)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2256
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2257
    int dstenc = $dst$$reg;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2258
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2259
    // movl $dst, -1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2260
    if (dstenc >= 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2261
      emit_opcode(cbuf, Assembler::REX_B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2262
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2263
    emit_opcode(cbuf, 0xB8 | (dstenc & 7));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2264
    emit_d32(cbuf, -1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2265
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2266
    // jp,s done
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2267
    emit_opcode(cbuf, 0x7A);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2268
    emit_d8(cbuf, dstenc < 4 ? 0x08 : 0x0A);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2269
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2270
    // jb,s done
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2271
    emit_opcode(cbuf, 0x72);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2272
    emit_d8(cbuf, dstenc < 4 ? 0x06 : 0x08);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2273
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2274
    // setne $dst
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2275
    if (dstenc >= 4) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2276
      emit_opcode(cbuf, dstenc < 8 ? Assembler::REX : Assembler::REX_B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2277
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2278
    emit_opcode(cbuf, 0x0F);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2279
    emit_opcode(cbuf, 0x95);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2280
    emit_opcode(cbuf, 0xC0 | (dstenc & 7));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2281
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2282
    // movzbl $dst, $dst
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2283
    if (dstenc >= 4) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2284
      emit_opcode(cbuf, dstenc < 8 ? Assembler::REX : Assembler::REX_RB);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2285
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2286
    emit_opcode(cbuf, 0x0F);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2287
    emit_opcode(cbuf, 0xB6);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2288
    emit_rm(cbuf, 0x3, dstenc & 7, dstenc & 7);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2289
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2290
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2291
  enc_class cdql_enc(no_rax_rdx_RegI div)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2292
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2293
    // Full implementation of Java idiv and irem; checks for
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2294
    // special case as described in JVM spec., p.243 & p.271.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2295
    //
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2296
    //         normal case                           special case
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2297
    //
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2298
    // input : rax: dividend                         min_int
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2299
    //         reg: divisor                          -1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2300
    //
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2301
    // output: rax: quotient  (= rax idiv reg)       min_int
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2302
    //         rdx: remainder (= rax irem reg)       0
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2303
    //
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2304
    //  Code sequnce:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2305
    //
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2306
    //    0:   3d 00 00 00 80          cmp    $0x80000000,%eax
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2307
    //    5:   75 07/08                jne    e <normal>
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2308
    //    7:   33 d2                   xor    %edx,%edx
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2309
    //  [div >= 8 -> offset + 1]
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2310
    //  [REX_B]
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2311
    //    9:   83 f9 ff                cmp    $0xffffffffffffffff,$div
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2312
    //    c:   74 03/04                je     11 <done>
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2313
    // 000000000000000e <normal>:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2314
    //    e:   99                      cltd
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2315
    //  [div >= 8 -> offset + 1]
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2316
    //  [REX_B]
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2317
    //    f:   f7 f9                   idiv   $div
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2318
    // 0000000000000011 <done>:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2319
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2320
    // cmp    $0x80000000,%eax
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2321
    emit_opcode(cbuf, 0x3d);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2322
    emit_d8(cbuf, 0x00);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2323
    emit_d8(cbuf, 0x00);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2324
    emit_d8(cbuf, 0x00);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2325
    emit_d8(cbuf, 0x80);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2326
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2327
    // jne    e <normal>
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2328
    emit_opcode(cbuf, 0x75);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2329
    emit_d8(cbuf, $div$$reg < 8 ? 0x07 : 0x08);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2330
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2331
    // xor    %edx,%edx
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2332
    emit_opcode(cbuf, 0x33);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2333
    emit_d8(cbuf, 0xD2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2334
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2335
    // cmp    $0xffffffffffffffff,%ecx
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2336
    if ($div$$reg >= 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2337
      emit_opcode(cbuf, Assembler::REX_B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2338
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2339
    emit_opcode(cbuf, 0x83);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2340
    emit_rm(cbuf, 0x3, 0x7, $div$$reg & 7);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2341
    emit_d8(cbuf, 0xFF);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2342
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2343
    // je     11 <done>
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2344
    emit_opcode(cbuf, 0x74);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2345
    emit_d8(cbuf, $div$$reg < 8 ? 0x03 : 0x04);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2346
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2347
    // <normal>
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2348
    // cltd
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2349
    emit_opcode(cbuf, 0x99);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2350
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2351
    // idivl (note: must be emitted by the user of this rule)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2352
    // <done>
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2353
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2354
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2355
  enc_class cdqq_enc(no_rax_rdx_RegL div)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2356
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2357
    // Full implementation of Java ldiv and lrem; checks for
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2358
    // special case as described in JVM spec., p.243 & p.271.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2359
    //
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2360
    //         normal case                           special case
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2361
    //
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2362
    // input : rax: dividend                         min_long
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2363
    //         reg: divisor                          -1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2364
    //
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2365
    // output: rax: quotient  (= rax idiv reg)       min_long
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2366
    //         rdx: remainder (= rax irem reg)       0
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2367
    //
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2368
    //  Code sequnce:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2369
    //
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2370
    //    0:   48 ba 00 00 00 00 00    mov    $0x8000000000000000,%rdx
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2371
    //    7:   00 00 80
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2372
    //    a:   48 39 d0                cmp    %rdx,%rax
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2373
    //    d:   75 08                   jne    17 <normal>
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2374
    //    f:   33 d2                   xor    %edx,%edx
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2375
    //   11:   48 83 f9 ff             cmp    $0xffffffffffffffff,$div
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2376
    //   15:   74 05                   je     1c <done>
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2377
    // 0000000000000017 <normal>:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2378
    //   17:   48 99                   cqto
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2379
    //   19:   48 f7 f9                idiv   $div
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2380
    // 000000000000001c <done>:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2381
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2382
    // mov    $0x8000000000000000,%rdx
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2383
    emit_opcode(cbuf, Assembler::REX_W);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2384
    emit_opcode(cbuf, 0xBA);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2385
    emit_d8(cbuf, 0x00);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2386
    emit_d8(cbuf, 0x00);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2387
    emit_d8(cbuf, 0x00);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2388
    emit_d8(cbuf, 0x00);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2389
    emit_d8(cbuf, 0x00);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2390
    emit_d8(cbuf, 0x00);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2391
    emit_d8(cbuf, 0x00);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2392
    emit_d8(cbuf, 0x80);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2393
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2394
    // cmp    %rdx,%rax
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2395
    emit_opcode(cbuf, Assembler::REX_W);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2396
    emit_opcode(cbuf, 0x39);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2397
    emit_d8(cbuf, 0xD0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2398
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2399
    // jne    17 <normal>
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2400
    emit_opcode(cbuf, 0x75);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2401
    emit_d8(cbuf, 0x08);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2402
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2403
    // xor    %edx,%edx
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2404
    emit_opcode(cbuf, 0x33);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2405
    emit_d8(cbuf, 0xD2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2406
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2407
    // cmp    $0xffffffffffffffff,$div
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2408
    emit_opcode(cbuf, $div$$reg < 8 ? Assembler::REX_W : Assembler::REX_WB);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2409
    emit_opcode(cbuf, 0x83);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2410
    emit_rm(cbuf, 0x3, 0x7, $div$$reg & 7);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2411
    emit_d8(cbuf, 0xFF);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2412
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2413
    // je     1e <done>
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2414
    emit_opcode(cbuf, 0x74);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2415
    emit_d8(cbuf, 0x05);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2416
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2417
    // <normal>
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2418
    // cqto
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2419
    emit_opcode(cbuf, Assembler::REX_W);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2420
    emit_opcode(cbuf, 0x99);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2421
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2422
    // idivq (note: must be emitted by the user of this rule)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2423
    // <done>
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2424
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2425
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2426
  // Opcde enc_class for 8/32 bit immediate instructions with sign-extension
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2427
  enc_class OpcSE(immI imm)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2428
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2429
    // Emit primary opcode and set sign-extend bit
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2430
    // Check for 8-bit immediate, and set sign extend bit in opcode
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2431
    if (-0x80 <= $imm$$constant && $imm$$constant < 0x80) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2432
      emit_opcode(cbuf, $primary | 0x02);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2433
    } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2434
      // 32-bit immediate
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2435
      emit_opcode(cbuf, $primary);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2436
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2437
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2438
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2439
  enc_class OpcSErm(rRegI dst, immI imm)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2440
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2441
    // OpcSEr/m
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2442
    int dstenc = $dst$$reg;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2443
    if (dstenc >= 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2444
      emit_opcode(cbuf, Assembler::REX_B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2445
      dstenc -= 8;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2446
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2447
    // Emit primary opcode and set sign-extend bit
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2448
    // Check for 8-bit immediate, and set sign extend bit in opcode
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2449
    if (-0x80 <= $imm$$constant && $imm$$constant < 0x80) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2450
      emit_opcode(cbuf, $primary | 0x02);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2451
    } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2452
      // 32-bit immediate
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2453
      emit_opcode(cbuf, $primary);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2454
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2455
    // Emit r/m byte with secondary opcode, after primary opcode.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2456
    emit_rm(cbuf, 0x3, $secondary, dstenc);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2457
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2458
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2459
  enc_class OpcSErm_wide(rRegL dst, immI imm)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2460
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2461
    // OpcSEr/m
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2462
    int dstenc = $dst$$reg;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2463
    if (dstenc < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2464
      emit_opcode(cbuf, Assembler::REX_W);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2465
    } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2466
      emit_opcode(cbuf, Assembler::REX_WB);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2467
      dstenc -= 8;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2468
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2469
    // Emit primary opcode and set sign-extend bit
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2470
    // Check for 8-bit immediate, and set sign extend bit in opcode
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2471
    if (-0x80 <= $imm$$constant && $imm$$constant < 0x80) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2472
      emit_opcode(cbuf, $primary | 0x02);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2473
    } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2474
      // 32-bit immediate
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2475
      emit_opcode(cbuf, $primary);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2476
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2477
    // Emit r/m byte with secondary opcode, after primary opcode.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2478
    emit_rm(cbuf, 0x3, $secondary, dstenc);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2479
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2480
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2481
  enc_class Con8or32(immI imm)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2482
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2483
    // Check for 8-bit immediate, and set sign extend bit in opcode
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2484
    if (-0x80 <= $imm$$constant && $imm$$constant < 0x80) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2485
      $$$emit8$imm$$constant;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2486
    } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2487
      // 32-bit immediate
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2488
      $$$emit32$imm$$constant;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2489
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2490
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2491
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2492
  enc_class Lbl(label labl)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2493
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2494
    // JMP, CALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2495
    Label* l = $labl$$label;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2496
    emit_d32(cbuf, l ? (l->loc_pos() - (cbuf.code_size() + 4)) : 0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2497
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2498
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2499
  enc_class LblShort(label labl)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2500
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2501
    // JMP, CALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2502
    Label* l = $labl$$label;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2503
    int disp = l ? (l->loc_pos() - (cbuf.code_size() + 1)) : 0;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2504
    assert(-128 <= disp && disp <= 127, "Displacement too large for short jmp");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2505
    emit_d8(cbuf, disp);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2506
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2507
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2508
  enc_class opc2_reg(rRegI dst)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2509
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2510
    // BSWAP
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2511
    emit_cc(cbuf, $secondary, $dst$$reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2512
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2513
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2514
  enc_class opc3_reg(rRegI dst)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2515
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2516
    // BSWAP
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2517
    emit_cc(cbuf, $tertiary, $dst$$reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2518
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2519
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2520
  enc_class reg_opc(rRegI div)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2521
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2522
    // INC, DEC, IDIV, IMOD, JMP indirect, ...
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2523
    emit_rm(cbuf, 0x3, $secondary, $div$$reg & 7);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2524
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2525
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2526
  enc_class Jcc(cmpOp cop, label labl)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2527
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2528
    // JCC
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2529
    Label* l = $labl$$label;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2530
    $$$emit8$primary;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2531
    emit_cc(cbuf, $secondary, $cop$$cmpcode);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2532
    emit_d32(cbuf, l ? (l->loc_pos() - (cbuf.code_size() + 4)) : 0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2533
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2534
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2535
  enc_class JccShort (cmpOp cop, label labl)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2536
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2537
  // JCC
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2538
    Label *l = $labl$$label;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2539
    emit_cc(cbuf, $primary, $cop$$cmpcode);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2540
    int disp = l ? (l->loc_pos() - (cbuf.code_size() + 1)) : 0;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2541
    assert(-128 <= disp && disp <= 127, "Displacement too large for short jmp");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2542
    emit_d8(cbuf, disp);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2543
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2544
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2545
  enc_class enc_cmov(cmpOp cop)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2546
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2547
    // CMOV
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2548
    $$$emit8$primary;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2549
    emit_cc(cbuf, $secondary, $cop$$cmpcode);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2550
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2551
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2552
  enc_class enc_cmovf_branch(cmpOp cop, regF dst, regF src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2553
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2554
    // Invert sense of branch from sense of cmov
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2555
    emit_cc(cbuf, 0x70, $cop$$cmpcode ^ 1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2556
    emit_d8(cbuf, ($dst$$reg < 8 && $src$$reg < 8)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2557
                  ? (UseXmmRegToRegMoveAll ? 3 : 4)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2558
                  : (UseXmmRegToRegMoveAll ? 4 : 5) ); // REX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2559
    // UseXmmRegToRegMoveAll ? movaps(dst, src) : movss(dst, src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2560
    if (!UseXmmRegToRegMoveAll) emit_opcode(cbuf, 0xF3);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2561
    if ($dst$$reg < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2562
      if ($src$$reg >= 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2563
        emit_opcode(cbuf, Assembler::REX_B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2564
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2565
    } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2566
      if ($src$$reg < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2567
        emit_opcode(cbuf, Assembler::REX_R);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2568
      } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2569
        emit_opcode(cbuf, Assembler::REX_RB);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2570
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2571
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2572
    emit_opcode(cbuf, 0x0F);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2573
    emit_opcode(cbuf, UseXmmRegToRegMoveAll ? 0x28 : 0x10);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2574
    emit_rm(cbuf, 0x3, $dst$$reg & 7, $src$$reg & 7);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2575
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2576
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2577
  enc_class enc_cmovd_branch(cmpOp cop, regD dst, regD src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2578
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2579
    // Invert sense of branch from sense of cmov
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2580
    emit_cc(cbuf, 0x70, $cop$$cmpcode ^ 1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2581
    emit_d8(cbuf, $dst$$reg < 8 && $src$$reg < 8 ? 4 : 5); // REX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2582
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2583
    //  UseXmmRegToRegMoveAll ? movapd(dst, src) : movsd(dst, src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2584
    emit_opcode(cbuf, UseXmmRegToRegMoveAll ? 0x66 : 0xF2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2585
    if ($dst$$reg < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2586
      if ($src$$reg >= 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2587
        emit_opcode(cbuf, Assembler::REX_B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2588
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2589
    } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2590
      if ($src$$reg < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2591
        emit_opcode(cbuf, Assembler::REX_R);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2592
      } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2593
        emit_opcode(cbuf, Assembler::REX_RB);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2594
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2595
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2596
    emit_opcode(cbuf, 0x0F);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2597
    emit_opcode(cbuf, UseXmmRegToRegMoveAll ? 0x28 : 0x10);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2598
    emit_rm(cbuf, 0x3, $dst$$reg & 7, $src$$reg & 7);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2599
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2600
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2601
  enc_class enc_PartialSubtypeCheck()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2602
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2603
    Register Rrdi = as_Register(RDI_enc); // result register
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2604
    Register Rrax = as_Register(RAX_enc); // super class
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2605
    Register Rrcx = as_Register(RCX_enc); // killed
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2606
    Register Rrsi = as_Register(RSI_enc); // sub class
2256
82d4e10b7c6b 6813212: factor duplicated assembly code for general subclass check (for 6655638)
jrose
parents: 2255
diff changeset
  2607
    Label miss;
82d4e10b7c6b 6813212: factor duplicated assembly code for general subclass check (for 6655638)
jrose
parents: 2255
diff changeset
  2608
    const bool set_cond_codes = true;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2609
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2610
    MacroAssembler _masm(&cbuf);
2256
82d4e10b7c6b 6813212: factor duplicated assembly code for general subclass check (for 6655638)
jrose
parents: 2255
diff changeset
  2611
    __ check_klass_subtype_slow_path(Rrsi, Rrax, Rrcx, Rrdi,
82d4e10b7c6b 6813212: factor duplicated assembly code for general subclass check (for 6655638)
jrose
parents: 2255
diff changeset
  2612
                                     NULL, &miss,
82d4e10b7c6b 6813212: factor duplicated assembly code for general subclass check (for 6655638)
jrose
parents: 2255
diff changeset
  2613
                                     /*set_cond_codes:*/ true);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2614
    if ($primary) {
1066
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  2615
      __ xorptr(Rrdi, Rrdi);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2616
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2617
    __ bind(miss);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2618
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2619
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2620
  enc_class Java_To_Interpreter(method meth)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2621
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2622
    // CALL Java_To_Interpreter
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2623
    // This is the instruction starting address for relocation info.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2624
    cbuf.set_inst_mark();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2625
    $$$emit8$primary;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2626
    // CALL directly to the runtime
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2627
    emit_d32_reloc(cbuf,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2628
                   (int) ($meth$$method - ((intptr_t) cbuf.code_end()) - 4),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2629
                   runtime_call_Relocation::spec(),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2630
                   RELOC_DISP32);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2631
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2632
4566
b363f6ef4068 6829187: compiler optimizations required for JSR 292
twisti
parents: 3908
diff changeset
  2633
  enc_class preserve_SP %{
b363f6ef4068 6829187: compiler optimizations required for JSR 292
twisti
parents: 3908
diff changeset
  2634
    debug_only(int off0 = cbuf.code_size());
b363f6ef4068 6829187: compiler optimizations required for JSR 292
twisti
parents: 3908
diff changeset
  2635
    MacroAssembler _masm(&cbuf);
b363f6ef4068 6829187: compiler optimizations required for JSR 292
twisti
parents: 3908
diff changeset
  2636
    // RBP is preserved across all calls, even compiled calls.
b363f6ef4068 6829187: compiler optimizations required for JSR 292
twisti
parents: 3908
diff changeset
  2637
    // Use it to preserve RSP in places where the callee might change the SP.
b363f6ef4068 6829187: compiler optimizations required for JSR 292
twisti
parents: 3908
diff changeset
  2638
    __ movptr(rbp, rsp);
b363f6ef4068 6829187: compiler optimizations required for JSR 292
twisti
parents: 3908
diff changeset
  2639
    debug_only(int off1 = cbuf.code_size());
b363f6ef4068 6829187: compiler optimizations required for JSR 292
twisti
parents: 3908
diff changeset
  2640
    assert(off1 - off0 == preserve_SP_size(), "correct size prediction");
b363f6ef4068 6829187: compiler optimizations required for JSR 292
twisti
parents: 3908
diff changeset
  2641
  %}
b363f6ef4068 6829187: compiler optimizations required for JSR 292
twisti
parents: 3908
diff changeset
  2642
b363f6ef4068 6829187: compiler optimizations required for JSR 292
twisti
parents: 3908
diff changeset
  2643
  enc_class restore_SP %{
b363f6ef4068 6829187: compiler optimizations required for JSR 292
twisti
parents: 3908
diff changeset
  2644
    MacroAssembler _masm(&cbuf);
b363f6ef4068 6829187: compiler optimizations required for JSR 292
twisti
parents: 3908
diff changeset
  2645
    __ movptr(rsp, rbp);
b363f6ef4068 6829187: compiler optimizations required for JSR 292
twisti
parents: 3908
diff changeset
  2646
  %}
b363f6ef4068 6829187: compiler optimizations required for JSR 292
twisti
parents: 3908
diff changeset
  2647
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2648
  enc_class Java_Static_Call(method meth)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2649
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2650
    // JAVA STATIC CALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2651
    // CALL to fixup routine.  Fixup routine uses ScopeDesc info to
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2652
    // determine who we intended to call.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2653
    cbuf.set_inst_mark();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2654
    $$$emit8$primary;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2655
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2656
    if (!_method) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2657
      emit_d32_reloc(cbuf,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2658
                     (int) ($meth$$method - ((intptr_t) cbuf.code_end()) - 4),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2659
                     runtime_call_Relocation::spec(),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2660
                     RELOC_DISP32);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2661
    } else if (_optimized_virtual) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2662
      emit_d32_reloc(cbuf,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2663
                     (int) ($meth$$method - ((intptr_t) cbuf.code_end()) - 4),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2664
                     opt_virtual_call_Relocation::spec(),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2665
                     RELOC_DISP32);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2666
    } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2667
      emit_d32_reloc(cbuf,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2668
                     (int) ($meth$$method - ((intptr_t) cbuf.code_end()) - 4),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2669
                     static_call_Relocation::spec(),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2670
                     RELOC_DISP32);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2671
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2672
    if (_method) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2673
      // Emit stub for static call
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2674
      emit_java_to_interp(cbuf);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2675
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2676
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2677
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2678
  enc_class Java_Dynamic_Call(method meth)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2679
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2680
    // JAVA DYNAMIC CALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2681
    // !!!!!
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2682
    // Generate  "movq rax, -1", placeholder instruction to load oop-info
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2683
    // emit_call_dynamic_prologue( cbuf );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2684
    cbuf.set_inst_mark();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2685
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2686
    // movq rax, -1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2687
    emit_opcode(cbuf, Assembler::REX_W);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2688
    emit_opcode(cbuf, 0xB8 | RAX_enc);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2689
    emit_d64_reloc(cbuf,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2690
                   (int64_t) Universe::non_oop_word(),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2691
                   oop_Relocation::spec_for_immediate(), RELOC_IMM64);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2692
    address virtual_call_oop_addr = cbuf.inst_mark();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2693
    // CALL to fixup routine.  Fixup routine uses ScopeDesc info to determine
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2694
    // who we intended to call.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2695
    cbuf.set_inst_mark();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2696
    $$$emit8$primary;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2697
    emit_d32_reloc(cbuf,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2698
                   (int) ($meth$$method - ((intptr_t) cbuf.code_end()) - 4),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2699
                   virtual_call_Relocation::spec(virtual_call_oop_addr),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2700
                   RELOC_DISP32);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2701
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2702
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2703
  enc_class Java_Compiled_Call(method meth)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2704
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2705
    // JAVA COMPILED CALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2706
    int disp = in_bytes(methodOopDesc:: from_compiled_offset());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2707
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2708
    // XXX XXX offset is 128 is 1.5 NON-PRODUCT !!!
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2709
    // assert(-0x80 <= disp && disp < 0x80, "compiled_code_offset isn't small");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2710
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2711
    // callq *disp(%rax)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2712
    cbuf.set_inst_mark();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2713
    $$$emit8$primary;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2714
    if (disp < 0x80) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2715
      emit_rm(cbuf, 0x01, $secondary, RAX_enc); // R/M byte
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2716
      emit_d8(cbuf, disp); // Displacement
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2717
    } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2718
      emit_rm(cbuf, 0x02, $secondary, RAX_enc); // R/M byte
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2719
      emit_d32(cbuf, disp); // Displacement
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2720
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2721
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2722
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2723
  enc_class reg_opc_imm(rRegI dst, immI8 shift)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2724
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2725
    // SAL, SAR, SHR
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2726
    int dstenc = $dst$$reg;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2727
    if (dstenc >= 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2728
      emit_opcode(cbuf, Assembler::REX_B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2729
      dstenc -= 8;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2730
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2731
    $$$emit8$primary;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2732
    emit_rm(cbuf, 0x3, $secondary, dstenc);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2733
    $$$emit8$shift$$constant;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2734
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2735
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2736
  enc_class reg_opc_imm_wide(rRegL dst, immI8 shift)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2737
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2738
    // SAL, SAR, SHR
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2739
    int dstenc = $dst$$reg;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2740
    if (dstenc < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2741
      emit_opcode(cbuf, Assembler::REX_W);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2742
    } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2743
      emit_opcode(cbuf, Assembler::REX_WB);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2744
      dstenc -= 8;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2745
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2746
    $$$emit8$primary;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2747
    emit_rm(cbuf, 0x3, $secondary, dstenc);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2748
    $$$emit8$shift$$constant;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2749
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2750
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2751
  enc_class load_immI(rRegI dst, immI src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2752
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2753
    int dstenc = $dst$$reg;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2754
    if (dstenc >= 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2755
      emit_opcode(cbuf, Assembler::REX_B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2756
      dstenc -= 8;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2757
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2758
    emit_opcode(cbuf, 0xB8 | dstenc);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2759
    $$$emit32$src$$constant;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2760
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2761
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2762
  enc_class load_immL(rRegL dst, immL src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2763
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2764
    int dstenc = $dst$$reg;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2765
    if (dstenc < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2766
      emit_opcode(cbuf, Assembler::REX_W);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2767
    } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2768
      emit_opcode(cbuf, Assembler::REX_WB);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2769
      dstenc -= 8;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2770
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2771
    emit_opcode(cbuf, 0xB8 | dstenc);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2772
    emit_d64(cbuf, $src$$constant);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2773
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2774
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2775
  enc_class load_immUL32(rRegL dst, immUL32 src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2776
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2777
    // same as load_immI, but this time we care about zeroes in the high word
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2778
    int dstenc = $dst$$reg;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2779
    if (dstenc >= 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2780
      emit_opcode(cbuf, Assembler::REX_B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2781
      dstenc -= 8;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2782
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2783
    emit_opcode(cbuf, 0xB8 | dstenc);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2784
    $$$emit32$src$$constant;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2785
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2786
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2787
  enc_class load_immL32(rRegL dst, immL32 src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2788
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2789
    int dstenc = $dst$$reg;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2790
    if (dstenc < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2791
      emit_opcode(cbuf, Assembler::REX_W);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2792
    } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2793
      emit_opcode(cbuf, Assembler::REX_WB);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2794
      dstenc -= 8;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2795
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2796
    emit_opcode(cbuf, 0xC7);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2797
    emit_rm(cbuf, 0x03, 0x00, dstenc);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2798
    $$$emit32$src$$constant;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2799
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2800
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2801
  enc_class load_immP31(rRegP dst, immP32 src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2802
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2803
    // same as load_immI, but this time we care about zeroes in the high word
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2804
    int dstenc = $dst$$reg;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2805
    if (dstenc >= 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2806
      emit_opcode(cbuf, Assembler::REX_B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2807
      dstenc -= 8;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2808
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2809
    emit_opcode(cbuf, 0xB8 | dstenc);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2810
    $$$emit32$src$$constant;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2811
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2812
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2813
  enc_class load_immP(rRegP dst, immP src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2814
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2815
    int dstenc = $dst$$reg;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2816
    if (dstenc < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2817
      emit_opcode(cbuf, Assembler::REX_W);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2818
    } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2819
      emit_opcode(cbuf, Assembler::REX_WB);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2820
      dstenc -= 8;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2821
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2822
    emit_opcode(cbuf, 0xB8 | dstenc);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2823
    // This next line should be generated from ADLC
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2824
    if ($src->constant_is_oop()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2825
      emit_d64_reloc(cbuf, $src$$constant, relocInfo::oop_type, RELOC_IMM64);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2826
    } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2827
      emit_d64(cbuf, $src$$constant);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2828
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2829
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2830
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2831
  enc_class load_immF(regF dst, immF con)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2832
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2833
    // XXX reg_mem doesn't support RIP-relative addressing yet
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2834
    emit_rm(cbuf, 0x0, $dst$$reg & 7, 0x5); // 00 reg 101
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2835
    emit_float_constant(cbuf, $con$$constant);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2836
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2837
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2838
  enc_class load_immD(regD dst, immD con)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2839
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2840
    // XXX reg_mem doesn't support RIP-relative addressing yet
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2841
    emit_rm(cbuf, 0x0, $dst$$reg & 7, 0x5); // 00 reg 101
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2842
    emit_double_constant(cbuf, $con$$constant);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2843
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2844
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2845
  enc_class load_conF (regF dst, immF con) %{    // Load float constant
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2846
    emit_opcode(cbuf, 0xF3);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2847
    if ($dst$$reg >= 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2848
      emit_opcode(cbuf, Assembler::REX_R);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2849
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2850
    emit_opcode(cbuf, 0x0F);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2851
    emit_opcode(cbuf, 0x10);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2852
    emit_rm(cbuf, 0x0, $dst$$reg & 7, 0x5); // 00 reg 101
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2853
    emit_float_constant(cbuf, $con$$constant);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2854
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2855
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2856
  enc_class load_conD (regD dst, immD con) %{    // Load double constant
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2857
    // UseXmmLoadAndClearUpper ? movsd(dst, con) : movlpd(dst, con)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2858
    emit_opcode(cbuf, UseXmmLoadAndClearUpper ? 0xF2 : 0x66);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2859
    if ($dst$$reg >= 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2860
      emit_opcode(cbuf, Assembler::REX_R);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2861
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2862
    emit_opcode(cbuf, 0x0F);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2863
    emit_opcode(cbuf, UseXmmLoadAndClearUpper ? 0x10 : 0x12);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2864
    emit_rm(cbuf, 0x0, $dst$$reg & 7, 0x5); // 00 reg 101
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2865
    emit_double_constant(cbuf, $con$$constant);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2866
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2867
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2868
  // Encode a reg-reg copy.  If it is useless, then empty encoding.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2869
  enc_class enc_copy(rRegI dst, rRegI src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2870
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2871
    encode_copy(cbuf, $dst$$reg, $src$$reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2872
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2873
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2874
  // Encode xmm reg-reg copy.  If it is useless, then empty encoding.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2875
  enc_class enc_CopyXD( RegD dst, RegD src ) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2876
    encode_CopyXD( cbuf, $dst$$reg, $src$$reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2877
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2878
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2879
  enc_class enc_copy_always(rRegI dst, rRegI src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2880
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2881
    int srcenc = $src$$reg;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2882
    int dstenc = $dst$$reg;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2883
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2884
    if (dstenc < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2885
      if (srcenc >= 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2886
        emit_opcode(cbuf, Assembler::REX_B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2887
        srcenc -= 8;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2888
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2889
    } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2890
      if (srcenc < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2891
        emit_opcode(cbuf, Assembler::REX_R);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2892
      } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2893
        emit_opcode(cbuf, Assembler::REX_RB);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2894
        srcenc -= 8;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2895
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2896
      dstenc -= 8;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2897
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2898
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2899
    emit_opcode(cbuf, 0x8B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2900
    emit_rm(cbuf, 0x3, dstenc, srcenc);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2901
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2902
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2903
  enc_class enc_copy_wide(rRegL dst, rRegL src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2904
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2905
    int srcenc = $src$$reg;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2906
    int dstenc = $dst$$reg;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2907
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2908
    if (dstenc != srcenc) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2909
      if (dstenc < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2910
        if (srcenc < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2911
          emit_opcode(cbuf, Assembler::REX_W);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2912
        } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2913
          emit_opcode(cbuf, Assembler::REX_WB);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2914
          srcenc -= 8;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2915
        }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2916
      } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2917
        if (srcenc < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2918
          emit_opcode(cbuf, Assembler::REX_WR);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2919
        } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2920
          emit_opcode(cbuf, Assembler::REX_WRB);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2921
          srcenc -= 8;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2922
        }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2923
        dstenc -= 8;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2924
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2925
      emit_opcode(cbuf, 0x8B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2926
      emit_rm(cbuf, 0x3, dstenc, srcenc);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2927
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2928
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2929
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2930
  enc_class Con32(immI src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2931
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2932
    // Output immediate
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2933
    $$$emit32$src$$constant;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2934
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2935
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2936
  enc_class Con64(immL src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2937
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2938
    // Output immediate
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2939
    emit_d64($src$$constant);
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 Con32F_as_bits(immF src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2943
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2944
    // Output Float immediate bits
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2945
    jfloat jf = $src$$constant;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2946
    jint jf_as_bits = jint_cast(jf);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2947
    emit_d32(cbuf, jf_as_bits);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2948
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2949
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2950
  enc_class Con16(immI src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2951
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2952
    // Output immediate
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2953
    $$$emit16$src$$constant;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2954
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2955
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2956
  // How is this different from Con32??? XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2957
  enc_class Con_d32(immI src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2958
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2959
    emit_d32(cbuf,$src$$constant);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2960
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2961
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2962
  enc_class conmemref (rRegP t1) %{    // Con32(storeImmI)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2963
    // Output immediate memory reference
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2964
    emit_rm(cbuf, 0x00, $t1$$reg, 0x05 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2965
    emit_d32(cbuf, 0x00);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2966
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2967
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2968
  enc_class jump_enc(rRegL switch_val, rRegI dest) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2969
    MacroAssembler masm(&cbuf);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2970
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2971
    Register switch_reg = as_Register($switch_val$$reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2972
    Register dest_reg   = as_Register($dest$$reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2973
    address table_base  = masm.address_table_constant(_index2label);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2974
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2975
    // We could use jump(ArrayAddress) except that the macro assembler needs to use r10
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2976
    // to do that and the compiler is using that register as one it can allocate.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2977
    // So we build it all by hand.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2978
    // Address index(noreg, switch_reg, Address::times_1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2979
    // ArrayAddress dispatch(table, index);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2980
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2981
    Address dispatch(dest_reg, switch_reg, Address::times_1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2982
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2983
    masm.lea(dest_reg, InternalAddress(table_base));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2984
    masm.jmp(dispatch);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2985
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2986
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2987
  enc_class jump_enc_addr(rRegL switch_val, immI2 shift, immL32 offset, rRegI dest) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2988
    MacroAssembler masm(&cbuf);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2989
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2990
    Register switch_reg = as_Register($switch_val$$reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2991
    Register dest_reg   = as_Register($dest$$reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2992
    address table_base  = masm.address_table_constant(_index2label);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2993
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2994
    // We could use jump(ArrayAddress) except that the macro assembler needs to use r10
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2995
    // to do that and the compiler is using that register as one it can allocate.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2996
    // So we build it all by hand.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2997
    // Address index(noreg, switch_reg, (Address::ScaleFactor)$shift$$constant, (int)$offset$$constant);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2998
    // ArrayAddress dispatch(table, index);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2999
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3000
    Address dispatch(dest_reg, switch_reg, (Address::ScaleFactor)$shift$$constant, (int)$offset$$constant);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3001
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3002
    masm.lea(dest_reg, InternalAddress(table_base));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3003
    masm.jmp(dispatch);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3004
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3005
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3006
  enc_class jump_enc_offset(rRegL switch_val, immI2 shift, rRegI dest) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3007
    MacroAssembler masm(&cbuf);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3008
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3009
    Register switch_reg = as_Register($switch_val$$reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3010
    Register dest_reg   = as_Register($dest$$reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3011
    address table_base  = masm.address_table_constant(_index2label);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3012
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3013
    // We could use jump(ArrayAddress) except that the macro assembler needs to use r10
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3014
    // to do that and the compiler is using that register as one it can allocate.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3015
    // So we build it all by hand.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3016
    // Address index(noreg, switch_reg, (Address::ScaleFactor)$shift$$constant);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3017
    // ArrayAddress dispatch(table, index);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3018
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3019
    Address dispatch(dest_reg, switch_reg, (Address::ScaleFactor)$shift$$constant);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3020
    masm.lea(dest_reg, InternalAddress(table_base));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3021
    masm.jmp(dispatch);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3022
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3023
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3024
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3025
  enc_class lock_prefix()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3026
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3027
    if (os::is_MP()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3028
      emit_opcode(cbuf, 0xF0); // lock
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3029
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3030
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3031
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3032
  enc_class REX_mem(memory mem)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3033
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3034
    if ($mem$$base >= 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3035
      if ($mem$$index < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3036
        emit_opcode(cbuf, Assembler::REX_B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3037
      } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3038
        emit_opcode(cbuf, Assembler::REX_XB);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3039
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3040
    } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3041
      if ($mem$$index >= 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3042
        emit_opcode(cbuf, Assembler::REX_X);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3043
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3044
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3045
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3046
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3047
  enc_class REX_mem_wide(memory mem)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3048
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3049
    if ($mem$$base >= 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3050
      if ($mem$$index < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3051
        emit_opcode(cbuf, Assembler::REX_WB);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3052
      } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3053
        emit_opcode(cbuf, Assembler::REX_WXB);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3054
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3055
    } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3056
      if ($mem$$index < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3057
        emit_opcode(cbuf, Assembler::REX_W);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3058
      } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3059
        emit_opcode(cbuf, Assembler::REX_WX);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3060
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3061
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3062
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3063
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3064
  // for byte regs
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3065
  enc_class REX_breg(rRegI reg)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3066
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3067
    if ($reg$$reg >= 4) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3068
      emit_opcode(cbuf, $reg$$reg < 8 ? Assembler::REX : Assembler::REX_B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3069
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3070
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3071
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3072
  // for byte regs
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3073
  enc_class REX_reg_breg(rRegI dst, rRegI src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3074
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3075
    if ($dst$$reg < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3076
      if ($src$$reg >= 4) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3077
        emit_opcode(cbuf, $src$$reg < 8 ? Assembler::REX : Assembler::REX_B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3078
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3079
    } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3080
      if ($src$$reg < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3081
        emit_opcode(cbuf, Assembler::REX_R);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3082
      } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3083
        emit_opcode(cbuf, Assembler::REX_RB);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3084
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3085
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3086
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3087
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3088
  // for byte regs
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3089
  enc_class REX_breg_mem(rRegI reg, memory mem)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3090
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3091
    if ($reg$$reg < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3092
      if ($mem$$base < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3093
        if ($mem$$index >= 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3094
          emit_opcode(cbuf, Assembler::REX_X);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3095
        } else if ($reg$$reg >= 4) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3096
          emit_opcode(cbuf, Assembler::REX);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3097
        }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3098
      } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3099
        if ($mem$$index < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3100
          emit_opcode(cbuf, Assembler::REX_B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3101
        } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3102
          emit_opcode(cbuf, Assembler::REX_XB);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3103
        }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3104
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3105
    } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3106
      if ($mem$$base < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3107
        if ($mem$$index < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3108
          emit_opcode(cbuf, Assembler::REX_R);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3109
        } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3110
          emit_opcode(cbuf, Assembler::REX_RX);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3111
        }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3112
      } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3113
        if ($mem$$index < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3114
          emit_opcode(cbuf, Assembler::REX_RB);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3115
        } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3116
          emit_opcode(cbuf, Assembler::REX_RXB);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3117
        }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3118
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3119
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3120
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3121
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3122
  enc_class REX_reg(rRegI reg)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3123
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3124
    if ($reg$$reg >= 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3125
      emit_opcode(cbuf, Assembler::REX_B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3126
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3127
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3128
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3129
  enc_class REX_reg_wide(rRegI reg)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3130
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3131
    if ($reg$$reg < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3132
      emit_opcode(cbuf, Assembler::REX_W);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3133
    } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3134
      emit_opcode(cbuf, Assembler::REX_WB);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3135
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3136
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3137
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3138
  enc_class REX_reg_reg(rRegI dst, rRegI src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3139
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3140
    if ($dst$$reg < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3141
      if ($src$$reg >= 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3142
        emit_opcode(cbuf, Assembler::REX_B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3143
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3144
    } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3145
      if ($src$$reg < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3146
        emit_opcode(cbuf, Assembler::REX_R);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3147
      } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3148
        emit_opcode(cbuf, Assembler::REX_RB);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3149
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3150
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3151
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3152
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3153
  enc_class REX_reg_reg_wide(rRegI dst, rRegI src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3154
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3155
    if ($dst$$reg < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3156
      if ($src$$reg < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3157
        emit_opcode(cbuf, Assembler::REX_W);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3158
      } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3159
        emit_opcode(cbuf, Assembler::REX_WB);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3160
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3161
    } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3162
      if ($src$$reg < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3163
        emit_opcode(cbuf, Assembler::REX_WR);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3164
      } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3165
        emit_opcode(cbuf, Assembler::REX_WRB);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3166
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3167
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3168
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3169
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3170
  enc_class REX_reg_mem(rRegI reg, memory mem)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3171
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3172
    if ($reg$$reg < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3173
      if ($mem$$base < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3174
        if ($mem$$index >= 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3175
          emit_opcode(cbuf, Assembler::REX_X);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3176
        }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3177
      } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3178
        if ($mem$$index < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3179
          emit_opcode(cbuf, Assembler::REX_B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3180
        } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3181
          emit_opcode(cbuf, Assembler::REX_XB);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3182
        }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3183
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3184
    } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3185
      if ($mem$$base < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3186
        if ($mem$$index < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3187
          emit_opcode(cbuf, Assembler::REX_R);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3188
        } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3189
          emit_opcode(cbuf, Assembler::REX_RX);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3190
        }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3191
      } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3192
        if ($mem$$index < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3193
          emit_opcode(cbuf, Assembler::REX_RB);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3194
        } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3195
          emit_opcode(cbuf, Assembler::REX_RXB);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3196
        }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3197
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3198
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3199
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3200
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3201
  enc_class REX_reg_mem_wide(rRegL reg, memory mem)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3202
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3203
    if ($reg$$reg < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3204
      if ($mem$$base < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3205
        if ($mem$$index < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3206
          emit_opcode(cbuf, Assembler::REX_W);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3207
        } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3208
          emit_opcode(cbuf, Assembler::REX_WX);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3209
        }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3210
      } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3211
        if ($mem$$index < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3212
          emit_opcode(cbuf, Assembler::REX_WB);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3213
        } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3214
          emit_opcode(cbuf, Assembler::REX_WXB);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3215
        }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3216
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3217
    } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3218
      if ($mem$$base < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3219
        if ($mem$$index < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3220
          emit_opcode(cbuf, Assembler::REX_WR);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3221
        } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3222
          emit_opcode(cbuf, Assembler::REX_WRX);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3223
        }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3224
      } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3225
        if ($mem$$index < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3226
          emit_opcode(cbuf, Assembler::REX_WRB);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3227
        } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3228
          emit_opcode(cbuf, Assembler::REX_WRXB);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3229
        }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3230
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3231
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3232
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3233
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3234
  enc_class reg_mem(rRegI ereg, memory mem)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3235
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3236
    // High registers handle in encode_RegMem
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3237
    int reg = $ereg$$reg;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3238
    int base = $mem$$base;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3239
    int index = $mem$$index;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3240
    int scale = $mem$$scale;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3241
    int disp = $mem$$disp;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3242
    bool disp_is_oop = $mem->disp_is_oop();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3243
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3244
    encode_RegMem(cbuf, reg, base, index, scale, disp, disp_is_oop);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3245
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3246
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3247
  enc_class RM_opc_mem(immI rm_opcode, memory mem)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3248
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3249
    int rm_byte_opcode = $rm_opcode$$constant;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3250
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3251
    // High registers handle in encode_RegMem
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3252
    int base = $mem$$base;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3253
    int index = $mem$$index;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3254
    int scale = $mem$$scale;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3255
    int displace = $mem$$disp;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3256
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3257
    bool disp_is_oop = $mem->disp_is_oop(); // disp-as-oop when
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3258
                                            // working with static
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3259
                                            // globals
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3260
    encode_RegMem(cbuf, rm_byte_opcode, base, index, scale, displace,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3261
                  disp_is_oop);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3262
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3263
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3264
  enc_class reg_lea(rRegI dst, rRegI src0, immI src1)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3265
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3266
    int reg_encoding = $dst$$reg;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3267
    int base         = $src0$$reg;      // 0xFFFFFFFF indicates no base
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3268
    int index        = 0x04;            // 0x04 indicates no index
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3269
    int scale        = 0x00;            // 0x00 indicates no scale
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3270
    int displace     = $src1$$constant; // 0x00 indicates no displacement
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3271
    bool disp_is_oop = false;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3272
    encode_RegMem(cbuf, reg_encoding, base, index, scale, displace,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3273
                  disp_is_oop);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3274
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3275
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3276
  enc_class neg_reg(rRegI dst)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3277
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3278
    int dstenc = $dst$$reg;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3279
    if (dstenc >= 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3280
      emit_opcode(cbuf, Assembler::REX_B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3281
      dstenc -= 8;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3282
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3283
    // NEG $dst
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3284
    emit_opcode(cbuf, 0xF7);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3285
    emit_rm(cbuf, 0x3, 0x03, dstenc);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3286
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3287
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3288
  enc_class neg_reg_wide(rRegI dst)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3289
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3290
    int dstenc = $dst$$reg;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3291
    if (dstenc < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3292
      emit_opcode(cbuf, Assembler::REX_W);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3293
    } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3294
      emit_opcode(cbuf, Assembler::REX_WB);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3295
      dstenc -= 8;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3296
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3297
    // NEG $dst
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3298
    emit_opcode(cbuf, 0xF7);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3299
    emit_rm(cbuf, 0x3, 0x03, dstenc);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3300
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3301
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3302
  enc_class setLT_reg(rRegI dst)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3303
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3304
    int dstenc = $dst$$reg;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3305
    if (dstenc >= 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3306
      emit_opcode(cbuf, Assembler::REX_B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3307
      dstenc -= 8;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3308
    } else if (dstenc >= 4) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3309
      emit_opcode(cbuf, Assembler::REX);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3310
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3311
    // SETLT $dst
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3312
    emit_opcode(cbuf, 0x0F);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3313
    emit_opcode(cbuf, 0x9C);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3314
    emit_rm(cbuf, 0x3, 0x0, dstenc);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3315
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3316
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3317
  enc_class setNZ_reg(rRegI dst)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3318
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3319
    int dstenc = $dst$$reg;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3320
    if (dstenc >= 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3321
      emit_opcode(cbuf, Assembler::REX_B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3322
      dstenc -= 8;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3323
    } else if (dstenc >= 4) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3324
      emit_opcode(cbuf, Assembler::REX);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3325
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3326
    // SETNZ $dst
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3327
    emit_opcode(cbuf, 0x0F);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3328
    emit_opcode(cbuf, 0x95);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3329
    emit_rm(cbuf, 0x3, 0x0, dstenc);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3330
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3331
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3332
  enc_class enc_cmpLTP(no_rcx_RegI p, no_rcx_RegI q, no_rcx_RegI y,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3333
                       rcx_RegI tmp)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3334
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3335
    // cadd_cmpLT
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3336
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3337
    int tmpReg = $tmp$$reg;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3338
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3339
    int penc = $p$$reg;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3340
    int qenc = $q$$reg;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3341
    int yenc = $y$$reg;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3342
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3343
    // subl $p,$q
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3344
    if (penc < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3345
      if (qenc >= 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3346
        emit_opcode(cbuf, Assembler::REX_B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3347
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3348
    } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3349
      if (qenc < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3350
        emit_opcode(cbuf, Assembler::REX_R);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3351
      } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3352
        emit_opcode(cbuf, Assembler::REX_RB);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3353
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3354
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3355
    emit_opcode(cbuf, 0x2B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3356
    emit_rm(cbuf, 0x3, penc & 7, qenc & 7);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3357
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3358
    // sbbl $tmp, $tmp
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3359
    emit_opcode(cbuf, 0x1B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3360
    emit_rm(cbuf, 0x3, tmpReg, tmpReg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3361
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3362
    // andl $tmp, $y
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3363
    if (yenc >= 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3364
      emit_opcode(cbuf, Assembler::REX_B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3365
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3366
    emit_opcode(cbuf, 0x23);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3367
    emit_rm(cbuf, 0x3, tmpReg, yenc & 7);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3368
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3369
    // addl $p,$tmp
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3370
    if (penc >= 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3371
        emit_opcode(cbuf, Assembler::REX_R);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3372
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3373
    emit_opcode(cbuf, 0x03);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3374
    emit_rm(cbuf, 0x3, penc & 7, tmpReg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3375
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3376
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3377
  // Compare the lonogs and set -1, 0, or 1 into dst
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3378
  enc_class cmpl3_flag(rRegL src1, rRegL src2, rRegI dst)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3379
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3380
    int src1enc = $src1$$reg;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3381
    int src2enc = $src2$$reg;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3382
    int dstenc = $dst$$reg;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3383
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3384
    // cmpq $src1, $src2
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3385
    if (src1enc < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3386
      if (src2enc < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3387
        emit_opcode(cbuf, Assembler::REX_W);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3388
      } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3389
        emit_opcode(cbuf, Assembler::REX_WB);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3390
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3391
    } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3392
      if (src2enc < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3393
        emit_opcode(cbuf, Assembler::REX_WR);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3394
      } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3395
        emit_opcode(cbuf, Assembler::REX_WRB);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3396
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3397
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3398
    emit_opcode(cbuf, 0x3B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3399
    emit_rm(cbuf, 0x3, src1enc & 7, src2enc & 7);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3400
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3401
    // movl $dst, -1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3402
    if (dstenc >= 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3403
      emit_opcode(cbuf, Assembler::REX_B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3404
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3405
    emit_opcode(cbuf, 0xB8 | (dstenc & 7));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3406
    emit_d32(cbuf, -1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3407
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3408
    // jl,s done
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3409
    emit_opcode(cbuf, 0x7C);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3410
    emit_d8(cbuf, dstenc < 4 ? 0x06 : 0x08);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3411
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3412
    // setne $dst
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3413
    if (dstenc >= 4) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3414
      emit_opcode(cbuf, dstenc < 8 ? Assembler::REX : Assembler::REX_B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3415
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3416
    emit_opcode(cbuf, 0x0F);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3417
    emit_opcode(cbuf, 0x95);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3418
    emit_opcode(cbuf, 0xC0 | (dstenc & 7));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3419
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3420
    // movzbl $dst, $dst
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3421
    if (dstenc >= 4) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3422
      emit_opcode(cbuf, dstenc < 8 ? Assembler::REX : Assembler::REX_RB);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3423
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3424
    emit_opcode(cbuf, 0x0F);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3425
    emit_opcode(cbuf, 0xB6);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3426
    emit_rm(cbuf, 0x3, dstenc & 7, dstenc & 7);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3427
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3428
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3429
  enc_class Push_ResultXD(regD dst) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3430
    int dstenc = $dst$$reg;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3431
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3432
    store_to_stackslot( cbuf, 0xDD, 0x03, 0 ); //FSTP [RSP]
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3433
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3434
    // UseXmmLoadAndClearUpper ? movsd dst,[rsp] : movlpd dst,[rsp]
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3435
    emit_opcode  (cbuf, UseXmmLoadAndClearUpper ? 0xF2 : 0x66);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3436
    if (dstenc >= 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3437
      emit_opcode(cbuf, Assembler::REX_R);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3438
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3439
    emit_opcode  (cbuf, 0x0F );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3440
    emit_opcode  (cbuf, UseXmmLoadAndClearUpper ? 0x10 : 0x12 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3441
    encode_RegMem(cbuf, dstenc, RSP_enc, 0x4, 0, 0, false);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3442
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3443
    // add rsp,8
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3444
    emit_opcode(cbuf, Assembler::REX_W);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3445
    emit_opcode(cbuf,0x83);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3446
    emit_rm(cbuf,0x3, 0x0, RSP_enc);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3447
    emit_d8(cbuf,0x08);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3448
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3449
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3450
  enc_class Push_SrcXD(regD src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3451
    int srcenc = $src$$reg;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3452
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3453
    // subq rsp,#8
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3454
    emit_opcode(cbuf, Assembler::REX_W);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3455
    emit_opcode(cbuf, 0x83);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3456
    emit_rm(cbuf, 0x3, 0x5, RSP_enc);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3457
    emit_d8(cbuf, 0x8);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3458
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3459
    // movsd [rsp],src
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3460
    emit_opcode(cbuf, 0xF2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3461
    if (srcenc >= 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3462
      emit_opcode(cbuf, Assembler::REX_R);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3463
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3464
    emit_opcode(cbuf, 0x0F);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3465
    emit_opcode(cbuf, 0x11);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3466
    encode_RegMem(cbuf, srcenc, RSP_enc, 0x4, 0, 0, false);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3467
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3468
    // fldd [rsp]
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3469
    emit_opcode(cbuf, 0x66);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3470
    emit_opcode(cbuf, 0xDD);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3471
    encode_RegMem(cbuf, 0x0, RSP_enc, 0x4, 0, 0, false);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3472
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3473
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3474
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3475
  enc_class movq_ld(regD dst, memory mem) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3476
    MacroAssembler _masm(&cbuf);
2150
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  3477
    __ movq($dst$$XMMRegister, $mem$$Address);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3478
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3479
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3480
  enc_class movq_st(memory mem, regD src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3481
    MacroAssembler _masm(&cbuf);
2150
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  3482
    __ movq($mem$$Address, $src$$XMMRegister);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3483
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3484
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3485
  enc_class pshufd_8x8(regF dst, regF src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3486
    MacroAssembler _masm(&cbuf);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3487
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3488
    encode_CopyXD(cbuf, $dst$$reg, $src$$reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3489
    __ punpcklbw(as_XMMRegister($dst$$reg), as_XMMRegister($dst$$reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3490
    __ pshuflw(as_XMMRegister($dst$$reg), as_XMMRegister($dst$$reg), 0x00);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3491
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3492
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3493
  enc_class pshufd_4x16(regF dst, regF src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3494
    MacroAssembler _masm(&cbuf);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3495
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3496
    __ pshuflw(as_XMMRegister($dst$$reg), as_XMMRegister($src$$reg), 0x00);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3497
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3498
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3499
  enc_class pshufd(regD dst, regD src, int mode) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3500
    MacroAssembler _masm(&cbuf);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3501
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3502
    __ pshufd(as_XMMRegister($dst$$reg), as_XMMRegister($src$$reg), $mode);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3503
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3504
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3505
  enc_class pxor(regD dst, regD src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3506
    MacroAssembler _masm(&cbuf);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3507
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3508
    __ pxor(as_XMMRegister($dst$$reg), as_XMMRegister($src$$reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3509
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3510
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3511
  enc_class mov_i2x(regD dst, rRegI src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3512
    MacroAssembler _masm(&cbuf);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3513
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3514
    __ movdl(as_XMMRegister($dst$$reg), as_Register($src$$reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3515
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3516
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3517
  // obj: object to lock
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3518
  // box: box address (header location) -- killed
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3519
  // tmp: rax -- killed
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3520
  // scr: rbx -- killed
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3521
  //
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3522
  // What follows is a direct transliteration of fast_lock() and fast_unlock()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3523
  // from i486.ad.  See that file for comments.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3524
  // TODO: where possible switch from movq (r, 0) to movl(r,0) and
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3525
  // use the shorter encoding.  (Movl clears the high-order 32-bits).
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3526
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3527
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3528
  enc_class Fast_Lock(rRegP obj, rRegP box, rax_RegI tmp, rRegP scr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3529
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3530
    Register objReg = as_Register((int)$obj$$reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3531
    Register boxReg = as_Register((int)$box$$reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3532
    Register tmpReg = as_Register($tmp$$reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3533
    Register scrReg = as_Register($scr$$reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3534
    MacroAssembler masm(&cbuf);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3535
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3536
    // Verify uniqueness of register assignments -- necessary but not sufficient
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3537
    assert (objReg != boxReg && objReg != tmpReg &&
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3538
            objReg != scrReg && tmpReg != scrReg, "invariant") ;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3539
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3540
    if (_counters != NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3541
      masm.atomic_incl(ExternalAddress((address) _counters->total_entry_count_addr()));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3542
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3543
    if (EmitSync & 1) {
1066
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3544
        // Without cast to int32_t a movptr will destroy r10 which is typically obj
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3545
        masm.movptr (Address(boxReg, 0), (int32_t)intptr_t(markOopDesc::unused_mark())) ; 
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3546
        masm.cmpptr(rsp, (int32_t)NULL_WORD) ; 
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3547
    } else
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3548
    if (EmitSync & 2) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3549
        Label DONE_LABEL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3550
        if (UseBiasedLocking) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3551
           // Note: tmpReg maps to the swap_reg argument and scrReg to the tmp_reg argument.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3552
          masm.biased_locking_enter(boxReg, objReg, tmpReg, scrReg, false, DONE_LABEL, NULL, _counters);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3553
        }
1066
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3554
        // QQQ was movl...
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3555
        masm.movptr(tmpReg, 0x1);
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3556
        masm.orptr(tmpReg, Address(objReg, 0));
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3557
        masm.movptr(Address(boxReg, 0), tmpReg);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3558
        if (os::is_MP()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3559
          masm.lock();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3560
        }
1066
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3561
        masm.cmpxchgptr(boxReg, Address(objReg, 0)); // Updates tmpReg
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3562
        masm.jcc(Assembler::equal, DONE_LABEL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3563
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3564
        // Recursive locking
1066
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3565
        masm.subptr(tmpReg, rsp);
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3566
        masm.andptr(tmpReg, 7 - os::vm_page_size());
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3567
        masm.movptr(Address(boxReg, 0), tmpReg);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3568
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3569
        masm.bind(DONE_LABEL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3570
        masm.nop(); // avoid branch to branch
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3571
    } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3572
        Label DONE_LABEL, IsInflated, Egress;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3573
1066
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3574
        masm.movptr(tmpReg, Address(objReg, 0)) ; 
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3575
        masm.testl (tmpReg, 0x02) ;         // inflated vs stack-locked|neutral|biased
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3576
        masm.jcc   (Assembler::notZero, IsInflated) ; 
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3577
         
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3578
        // it's stack-locked, biased or neutral
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3579
        // TODO: optimize markword triage order to reduce the number of
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3580
        // conditional branches in the most common cases.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3581
        // Beware -- there's a subtle invariant that fetch of the markword
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3582
        // at [FETCH], below, will never observe a biased encoding (*101b).
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3583
        // If this invariant is not held we'll suffer exclusion (safety) failure.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3584
1500
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
  3585
        if (UseBiasedLocking && !UseOptoBiasInlining) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3586
          masm.biased_locking_enter(boxReg, objReg, tmpReg, scrReg, true, DONE_LABEL, NULL, _counters);
1066
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3587
          masm.movptr(tmpReg, Address(objReg, 0)) ;        // [FETCH]
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3588
        }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3589
1066
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3590
        // was q will it destroy high?
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3591
        masm.orl   (tmpReg, 1) ; 
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3592
        masm.movptr(Address(boxReg, 0), tmpReg) ;  
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3593
        if (os::is_MP()) { masm.lock(); } 
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3594
        masm.cmpxchgptr(boxReg, Address(objReg, 0)); // Updates tmpReg
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3595
        if (_counters != NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3596
           masm.cond_inc32(Assembler::equal,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3597
                           ExternalAddress((address) _counters->fast_path_entry_count_addr()));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3598
        }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3599
        masm.jcc   (Assembler::equal, DONE_LABEL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3600
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3601
        // Recursive locking
1066
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3602
        masm.subptr(tmpReg, rsp);
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3603
        masm.andptr(tmpReg, 7 - os::vm_page_size());
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3604
        masm.movptr(Address(boxReg, 0), tmpReg);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3605
        if (_counters != NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3606
           masm.cond_inc32(Assembler::equal,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3607
                           ExternalAddress((address) _counters->fast_path_entry_count_addr()));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3608
        }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3609
        masm.jmp   (DONE_LABEL) ;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3610
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3611
        masm.bind  (IsInflated) ;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3612
        // It's inflated
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3613
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3614
        // TODO: someday avoid the ST-before-CAS penalty by
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3615
        // relocating (deferring) the following ST.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3616
        // We should also think about trying a CAS without having
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3617
        // fetched _owner.  If the CAS is successful we may
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3618
        // avoid an RTO->RTS upgrade on the $line.
1066
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3619
        // Without cast to int32_t a movptr will destroy r10 which is typically obj
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3620
        masm.movptr(Address(boxReg, 0), (int32_t)intptr_t(markOopDesc::unused_mark())) ; 
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3621
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3622
        masm.mov    (boxReg, tmpReg) ; 
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3623
        masm.movptr (tmpReg, Address(tmpReg, ObjectMonitor::owner_offset_in_bytes()-2)) ; 
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3624
        masm.testptr(tmpReg, tmpReg) ;   
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3625
        masm.jcc    (Assembler::notZero, DONE_LABEL) ; 
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3626
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3627
        // It's inflated and appears unlocked
1066
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3628
        if (os::is_MP()) { masm.lock(); } 
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3629
        masm.cmpxchgptr(r15_thread, Address(boxReg, ObjectMonitor::owner_offset_in_bytes()-2)) ; 
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3630
        // Intentional fall-through into DONE_LABEL ...
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3631
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3632
        masm.bind  (DONE_LABEL) ;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3633
        masm.nop   () ;                 // avoid jmp to jmp
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3634
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3635
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3636
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3637
  // obj: object to unlock
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3638
  // box: box address (displaced header location), killed
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3639
  // RBX: killed tmp; cannot be obj nor box
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3640
  enc_class Fast_Unlock(rRegP obj, rax_RegP box, rRegP tmp)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3641
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3642
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3643
    Register objReg = as_Register($obj$$reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3644
    Register boxReg = as_Register($box$$reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3645
    Register tmpReg = as_Register($tmp$$reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3646
    MacroAssembler masm(&cbuf);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3647
1066
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3648
    if (EmitSync & 4) { 
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3649
       masm.cmpptr(rsp, 0) ; 
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3650
    } else
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3651
    if (EmitSync & 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3652
       Label DONE_LABEL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3653
       if (UseBiasedLocking) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3654
         masm.biased_locking_exit(objReg, tmpReg, DONE_LABEL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3655
       }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3656
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3657
       // Check whether the displaced header is 0
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3658
       //(=> recursive unlock)
1066
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3659
       masm.movptr(tmpReg, Address(boxReg, 0));
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3660
       masm.testptr(tmpReg, tmpReg);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3661
       masm.jcc(Assembler::zero, DONE_LABEL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3662
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3663
       // If not recursive lock, reset the header to displaced header
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3664
       if (os::is_MP()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3665
         masm.lock();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3666
       }
1066
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3667
       masm.cmpxchgptr(tmpReg, Address(objReg, 0)); // Uses RAX which is box
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3668
       masm.bind(DONE_LABEL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3669
       masm.nop(); // avoid branch to branch
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3670
    } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3671
       Label DONE_LABEL, Stacked, CheckSucc ;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3672
1500
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
  3673
       if (UseBiasedLocking && !UseOptoBiasInlining) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3674
         masm.biased_locking_exit(objReg, tmpReg, DONE_LABEL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3675
       }
1066
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3676
        
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3677
       masm.movptr(tmpReg, Address(objReg, 0)) ; 
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3678
       masm.cmpptr(Address(boxReg, 0), (int32_t)NULL_WORD) ; 
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3679
       masm.jcc   (Assembler::zero, DONE_LABEL) ; 
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3680
       masm.testl (tmpReg, 0x02) ; 
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3681
       masm.jcc   (Assembler::zero, Stacked) ; 
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3682
        
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3683
       // It's inflated
1066
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3684
       masm.movptr(boxReg, Address (tmpReg, ObjectMonitor::owner_offset_in_bytes()-2)) ; 
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3685
       masm.xorptr(boxReg, r15_thread) ; 
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3686
       masm.orptr (boxReg, Address (tmpReg, ObjectMonitor::recursions_offset_in_bytes()-2)) ; 
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3687
       masm.jcc   (Assembler::notZero, DONE_LABEL) ; 
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3688
       masm.movptr(boxReg, Address (tmpReg, ObjectMonitor::cxq_offset_in_bytes()-2)) ; 
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3689
       masm.orptr (boxReg, Address (tmpReg, ObjectMonitor::EntryList_offset_in_bytes()-2)) ; 
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3690
       masm.jcc   (Assembler::notZero, CheckSucc) ; 
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3691
       masm.movptr(Address (tmpReg, ObjectMonitor::owner_offset_in_bytes()-2), (int32_t)NULL_WORD) ; 
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3692
       masm.jmp   (DONE_LABEL) ; 
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3693
        
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3694
       if ((EmitSync & 65536) == 0) { 
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3695
         Label LSuccess, LGoSlowPath ;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3696
         masm.bind  (CheckSucc) ;
1066
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3697
         masm.cmpptr(Address (tmpReg, ObjectMonitor::succ_offset_in_bytes()-2), (int32_t)NULL_WORD) ;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3698
         masm.jcc   (Assembler::zero, LGoSlowPath) ;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3699
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3700
         // I'd much rather use lock:andl m->_owner, 0 as it's faster than the
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3701
         // the explicit ST;MEMBAR combination, but masm doesn't currently support
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3702
         // "ANDQ M,IMM".  Don't use MFENCE here.  lock:add to TOS, xchg, etc
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3703
         // are all faster when the write buffer is populated.
1066
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3704
         masm.movptr (Address (tmpReg, ObjectMonitor::owner_offset_in_bytes()-2), (int32_t)NULL_WORD) ;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3705
         if (os::is_MP()) {
1066
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3706
            masm.lock () ; masm.addl (Address(rsp, 0), 0) ;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3707
         }
1066
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3708
         masm.cmpptr(Address (tmpReg, ObjectMonitor::succ_offset_in_bytes()-2), (int32_t)NULL_WORD) ;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3709
         masm.jcc   (Assembler::notZero, LSuccess) ;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3710
1066
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3711
         masm.movptr (boxReg, (int32_t)NULL_WORD) ;                   // box is really EAX
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3712
         if (os::is_MP()) { masm.lock(); }
1066
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3713
         masm.cmpxchgptr(r15_thread, Address(tmpReg, ObjectMonitor::owner_offset_in_bytes()-2));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3714
         masm.jcc   (Assembler::notEqual, LSuccess) ;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3715
         // Intentional fall-through into slow-path
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3716
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3717
         masm.bind  (LGoSlowPath) ;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3718
         masm.orl   (boxReg, 1) ;                      // set ICC.ZF=0 to indicate failure
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3719
         masm.jmp   (DONE_LABEL) ;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3720
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3721
         masm.bind  (LSuccess) ;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3722
         masm.testl (boxReg, 0) ;                      // set ICC.ZF=1 to indicate success
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3723
         masm.jmp   (DONE_LABEL) ;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3724
       }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3725
1066
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3726
       masm.bind  (Stacked) ; 
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3727
       masm.movptr(tmpReg, Address (boxReg, 0)) ;      // re-fetch
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3728
       if (os::is_MP()) { masm.lock(); } 
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3729
       masm.cmpxchgptr(tmpReg, Address(objReg, 0)); // Uses RAX which is box
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3730
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3731
       if (EmitSync & 65536) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3732
          masm.bind (CheckSucc) ;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3733
       }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3734
       masm.bind(DONE_LABEL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3735
       if (EmitSync & 32768) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3736
          masm.nop();                      // avoid branch to branch
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3737
       }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3738
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3739
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3740
595
a2be4c89de81 6695049: (coll) Create an x86 intrinsic for Arrays.equals
rasbold
parents: 594
diff changeset
  3741
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3742
  enc_class enc_rethrow()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3743
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3744
    cbuf.set_inst_mark();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3745
    emit_opcode(cbuf, 0xE9); // jmp entry
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3746
    emit_d32_reloc(cbuf,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3747
                   (int) (OptoRuntime::rethrow_stub() - cbuf.code_end() - 4),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3748
                   runtime_call_Relocation::spec(),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3749
                   RELOC_DISP32);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3750
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3751
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3752
  enc_class absF_encoding(regF dst)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3753
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3754
    int dstenc = $dst$$reg;
1066
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3755
    address signmask_address = (address) StubRoutines::x86::float_sign_mask();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3756
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3757
    cbuf.set_inst_mark();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3758
    if (dstenc >= 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3759
      emit_opcode(cbuf, Assembler::REX_R);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3760
      dstenc -= 8;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3761
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3762
    // XXX reg_mem doesn't support RIP-relative addressing yet
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3763
    emit_opcode(cbuf, 0x0F);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3764
    emit_opcode(cbuf, 0x54);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3765
    emit_rm(cbuf, 0x0, dstenc, 0x5);  // 00 reg 101
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3766
    emit_d32_reloc(cbuf, signmask_address);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3767
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3768
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3769
  enc_class absD_encoding(regD dst)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3770
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3771
    int dstenc = $dst$$reg;
1066
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3772
    address signmask_address = (address) StubRoutines::x86::double_sign_mask();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3773
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3774
    cbuf.set_inst_mark();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3775
    emit_opcode(cbuf, 0x66);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3776
    if (dstenc >= 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3777
      emit_opcode(cbuf, Assembler::REX_R);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3778
      dstenc -= 8;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3779
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3780
    // XXX reg_mem doesn't support RIP-relative addressing yet
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3781
    emit_opcode(cbuf, 0x0F);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3782
    emit_opcode(cbuf, 0x54);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3783
    emit_rm(cbuf, 0x0, dstenc, 0x5);  // 00 reg 101
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3784
    emit_d32_reloc(cbuf, signmask_address);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3785
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3786
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3787
  enc_class negF_encoding(regF dst)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3788
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3789
    int dstenc = $dst$$reg;
1066
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3790
    address signflip_address = (address) StubRoutines::x86::float_sign_flip();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3791
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3792
    cbuf.set_inst_mark();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3793
    if (dstenc >= 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3794
      emit_opcode(cbuf, Assembler::REX_R);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3795
      dstenc -= 8;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3796
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3797
    // XXX reg_mem doesn't support RIP-relative addressing yet
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3798
    emit_opcode(cbuf, 0x0F);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3799
    emit_opcode(cbuf, 0x57);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3800
    emit_rm(cbuf, 0x0, dstenc, 0x5);  // 00 reg 101
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3801
    emit_d32_reloc(cbuf, signflip_address);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3802
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3803
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3804
  enc_class negD_encoding(regD dst)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3805
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3806
    int dstenc = $dst$$reg;
1066
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3807
    address signflip_address = (address) StubRoutines::x86::double_sign_flip();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3808
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3809
    cbuf.set_inst_mark();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3810
    emit_opcode(cbuf, 0x66);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3811
    if (dstenc >= 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3812
      emit_opcode(cbuf, Assembler::REX_R);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3813
      dstenc -= 8;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3814
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3815
    // XXX reg_mem doesn't support RIP-relative addressing yet
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3816
    emit_opcode(cbuf, 0x0F);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3817
    emit_opcode(cbuf, 0x57);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3818
    emit_rm(cbuf, 0x0, dstenc, 0x5);  // 00 reg 101
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3819
    emit_d32_reloc(cbuf, signflip_address);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3820
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3821
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3822
  enc_class f2i_fixup(rRegI dst, regF src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3823
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3824
    int dstenc = $dst$$reg;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3825
    int srcenc = $src$$reg;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3826
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3827
    // cmpl $dst, #0x80000000
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3828
    if (dstenc >= 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3829
      emit_opcode(cbuf, Assembler::REX_B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3830
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3831
    emit_opcode(cbuf, 0x81);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3832
    emit_rm(cbuf, 0x3, 0x7, dstenc & 7);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3833
    emit_d32(cbuf, 0x80000000);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3834
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3835
    // jne,s done
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3836
    emit_opcode(cbuf, 0x75);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3837
    if (srcenc < 8 && dstenc < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3838
      emit_d8(cbuf, 0xF);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3839
    } else if (srcenc >= 8 && dstenc >= 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3840
      emit_d8(cbuf, 0x11);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3841
    } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3842
      emit_d8(cbuf, 0x10);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3843
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3844
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3845
    // subq rsp, #8
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3846
    emit_opcode(cbuf, Assembler::REX_W);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3847
    emit_opcode(cbuf, 0x83);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3848
    emit_rm(cbuf, 0x3, 0x5, RSP_enc);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3849
    emit_d8(cbuf, 8);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3850
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3851
    // movss [rsp], $src
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3852
    emit_opcode(cbuf, 0xF3);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3853
    if (srcenc >= 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3854
      emit_opcode(cbuf, Assembler::REX_R);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3855
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3856
    emit_opcode(cbuf, 0x0F);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3857
    emit_opcode(cbuf, 0x11);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3858
    encode_RegMem(cbuf, srcenc, RSP_enc, 0x4, 0, 0, false); // 2 bytes
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3859
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3860
    // call f2i_fixup
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3861
    cbuf.set_inst_mark();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3862
    emit_opcode(cbuf, 0xE8);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3863
    emit_d32_reloc(cbuf,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3864
                   (int)
1066
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3865
                   (StubRoutines::x86::f2i_fixup() - cbuf.code_end() - 4),
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3866
                   runtime_call_Relocation::spec(),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3867
                   RELOC_DISP32);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3868
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3869
    // popq $dst
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3870
    if (dstenc >= 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3871
      emit_opcode(cbuf, Assembler::REX_B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3872
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3873
    emit_opcode(cbuf, 0x58 | (dstenc & 7));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3874
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3875
    // done:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3876
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3877
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3878
  enc_class f2l_fixup(rRegL dst, regF src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3879
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3880
    int dstenc = $dst$$reg;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3881
    int srcenc = $src$$reg;
1066
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3882
    address const_address = (address) StubRoutines::x86::double_sign_flip();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3883
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3884
    // cmpq $dst, [0x8000000000000000]
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3885
    cbuf.set_inst_mark();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3886
    emit_opcode(cbuf, dstenc < 8 ? Assembler::REX_W : Assembler::REX_WR);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3887
    emit_opcode(cbuf, 0x39);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3888
    // XXX reg_mem doesn't support RIP-relative addressing yet
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3889
    emit_rm(cbuf, 0x0, dstenc & 7, 0x5); // 00 reg 101
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3890
    emit_d32_reloc(cbuf, const_address);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3891
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3892
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3893
    // jne,s done
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3894
    emit_opcode(cbuf, 0x75);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3895
    if (srcenc < 8 && dstenc < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3896
      emit_d8(cbuf, 0xF);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3897
    } else if (srcenc >= 8 && dstenc >= 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3898
      emit_d8(cbuf, 0x11);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3899
    } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3900
      emit_d8(cbuf, 0x10);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3901
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3902
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3903
    // subq rsp, #8
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3904
    emit_opcode(cbuf, Assembler::REX_W);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3905
    emit_opcode(cbuf, 0x83);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3906
    emit_rm(cbuf, 0x3, 0x5, RSP_enc);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3907
    emit_d8(cbuf, 8);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3908
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3909
    // movss [rsp], $src
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3910
    emit_opcode(cbuf, 0xF3);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3911
    if (srcenc >= 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3912
      emit_opcode(cbuf, Assembler::REX_R);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3913
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3914
    emit_opcode(cbuf, 0x0F);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3915
    emit_opcode(cbuf, 0x11);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3916
    encode_RegMem(cbuf, srcenc, RSP_enc, 0x4, 0, 0, false); // 2 bytes
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3917
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3918
    // call f2l_fixup
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3919
    cbuf.set_inst_mark();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3920
    emit_opcode(cbuf, 0xE8);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3921
    emit_d32_reloc(cbuf,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3922
                   (int)
1066
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3923
                   (StubRoutines::x86::f2l_fixup() - cbuf.code_end() - 4),
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3924
                   runtime_call_Relocation::spec(),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3925
                   RELOC_DISP32);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3926
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3927
    // popq $dst
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3928
    if (dstenc >= 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3929
      emit_opcode(cbuf, Assembler::REX_B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3930
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3931
    emit_opcode(cbuf, 0x58 | (dstenc & 7));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3932
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3933
    // done:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3934
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3935
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3936
  enc_class d2i_fixup(rRegI dst, regD src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3937
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3938
    int dstenc = $dst$$reg;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3939
    int srcenc = $src$$reg;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3940
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3941
    // cmpl $dst, #0x80000000
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3942
    if (dstenc >= 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3943
      emit_opcode(cbuf, Assembler::REX_B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3944
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3945
    emit_opcode(cbuf, 0x81);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3946
    emit_rm(cbuf, 0x3, 0x7, dstenc & 7);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3947
    emit_d32(cbuf, 0x80000000);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3948
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3949
    // jne,s done
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3950
    emit_opcode(cbuf, 0x75);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3951
    if (srcenc < 8 && dstenc < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3952
      emit_d8(cbuf, 0xF);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3953
    } else if (srcenc >= 8 && dstenc >= 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3954
      emit_d8(cbuf, 0x11);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3955
    } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3956
      emit_d8(cbuf, 0x10);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3957
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3958
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3959
    // subq rsp, #8
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3960
    emit_opcode(cbuf, Assembler::REX_W);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3961
    emit_opcode(cbuf, 0x83);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3962
    emit_rm(cbuf, 0x3, 0x5, RSP_enc);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3963
    emit_d8(cbuf, 8);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3964
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3965
    // movsd [rsp], $src
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3966
    emit_opcode(cbuf, 0xF2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3967
    if (srcenc >= 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3968
      emit_opcode(cbuf, Assembler::REX_R);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3969
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3970
    emit_opcode(cbuf, 0x0F);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3971
    emit_opcode(cbuf, 0x11);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3972
    encode_RegMem(cbuf, srcenc, RSP_enc, 0x4, 0, 0, false); // 2 bytes
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3973
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3974
    // call d2i_fixup
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3975
    cbuf.set_inst_mark();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3976
    emit_opcode(cbuf, 0xE8);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3977
    emit_d32_reloc(cbuf,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3978
                   (int)
1066
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3979
                   (StubRoutines::x86::d2i_fixup() - cbuf.code_end() - 4),
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3980
                   runtime_call_Relocation::spec(),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3981
                   RELOC_DISP32);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3982
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3983
    // popq $dst
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3984
    if (dstenc >= 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3985
      emit_opcode(cbuf, Assembler::REX_B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3986
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3987
    emit_opcode(cbuf, 0x58 | (dstenc & 7));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3988
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3989
    // done:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3990
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3991
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3992
  enc_class d2l_fixup(rRegL dst, regD src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3993
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3994
    int dstenc = $dst$$reg;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3995
    int srcenc = $src$$reg;
1066
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  3996
    address const_address = (address) StubRoutines::x86::double_sign_flip();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3997
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3998
    // cmpq $dst, [0x8000000000000000]
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3999
    cbuf.set_inst_mark();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4000
    emit_opcode(cbuf, dstenc < 8 ? Assembler::REX_W : Assembler::REX_WR);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4001
    emit_opcode(cbuf, 0x39);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4002
    // XXX reg_mem doesn't support RIP-relative addressing yet
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4003
    emit_rm(cbuf, 0x0, dstenc & 7, 0x5); // 00 reg 101
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4004
    emit_d32_reloc(cbuf, const_address);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4005
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4006
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4007
    // jne,s done
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4008
    emit_opcode(cbuf, 0x75);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4009
    if (srcenc < 8 && dstenc < 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4010
      emit_d8(cbuf, 0xF);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4011
    } else if (srcenc >= 8 && dstenc >= 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4012
      emit_d8(cbuf, 0x11);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4013
    } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4014
      emit_d8(cbuf, 0x10);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4015
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4016
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4017
    // subq rsp, #8
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4018
    emit_opcode(cbuf, Assembler::REX_W);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4019
    emit_opcode(cbuf, 0x83);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4020
    emit_rm(cbuf, 0x3, 0x5, RSP_enc);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4021
    emit_d8(cbuf, 8);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4022
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4023
    // movsd [rsp], $src
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4024
    emit_opcode(cbuf, 0xF2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4025
    if (srcenc >= 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4026
      emit_opcode(cbuf, Assembler::REX_R);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4027
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4028
    emit_opcode(cbuf, 0x0F);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4029
    emit_opcode(cbuf, 0x11);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4030
    encode_RegMem(cbuf, srcenc, RSP_enc, 0x4, 0, 0, false); // 2 bytes
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4031
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4032
    // call d2l_fixup
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4033
    cbuf.set_inst_mark();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4034
    emit_opcode(cbuf, 0xE8);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4035
    emit_d32_reloc(cbuf,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4036
                   (int)
1066
717c3345024f 5108146: Merge i486 and amd64 cpu directories
never
parents: 781
diff changeset
  4037
                   (StubRoutines::x86::d2l_fixup() - cbuf.code_end() - 4),
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4038
                   runtime_call_Relocation::spec(),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4039
                   RELOC_DISP32);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4040
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4041
    // popq $dst
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4042
    if (dstenc >= 8) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4043
      emit_opcode(cbuf, Assembler::REX_B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4044
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4045
    emit_opcode(cbuf, 0x58 | (dstenc & 7));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4046
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4047
    // done:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4048
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4049
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4050
  // Safepoint Poll.  This polls the safepoint page, and causes an
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4051
  // exception if it is not readable. Unfortunately, it kills
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4052
  // RFLAGS in the process.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4053
  enc_class enc_safepoint_poll
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4054
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4055
    // testl %rax, off(%rip) // Opcode + ModRM + Disp32 == 6 bytes
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4056
    // XXX reg_mem doesn't support RIP-relative addressing yet
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4057
    cbuf.set_inst_mark();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4058
    cbuf.relocate(cbuf.inst_mark(), relocInfo::poll_type, 0); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4059
    emit_opcode(cbuf, 0x85); // testl
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4060
    emit_rm(cbuf, 0x0, RAX_enc, 0x5); // 00 rax 101 == 0x5
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4061
    // cbuf.inst_mark() is beginning of instruction
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4062
    emit_d32_reloc(cbuf, os::get_polling_page());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4063
//                    relocInfo::poll_type,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4064
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4065
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4066
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4067
360
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  4068
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4069
//----------FRAME--------------------------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4070
// Definition of frame structure and management information.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4071
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4072
//  S T A C K   L A Y O U T    Allocators stack-slot number
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4073
//                             |   (to get allocators register number
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4074
//  G  Owned by    |        |  v    add OptoReg::stack0())
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4075
//  r   CALLER     |        |
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4076
//  o     |        +--------+      pad to even-align allocators stack-slot
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4077
//  w     V        |  pad0  |        numbers; owned by CALLER
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4078
//  t   -----------+--------+----> Matcher::_in_arg_limit, unaligned
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4079
//  h     ^        |   in   |  5
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4080
//        |        |  args  |  4   Holes in incoming args owned by SELF
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4081
//  |     |        |        |  3
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4082
//  |     |        +--------+
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4083
//  V     |        | old out|      Empty on Intel, window on Sparc
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4084
//        |    old |preserve|      Must be even aligned.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4085
//        |     SP-+--------+----> Matcher::_old_SP, even aligned
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4086
//        |        |   in   |  3   area for Intel ret address
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4087
//     Owned by    |preserve|      Empty on Sparc.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4088
//       SELF      +--------+
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4089
//        |        |  pad2  |  2   pad to align old SP
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4090
//        |        +--------+  1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4091
//        |        | locks  |  0
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4092
//        |        +--------+----> OptoReg::stack0(), even aligned
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4093
//        |        |  pad1  | 11   pad to align new SP
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4094
//        |        +--------+
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4095
//        |        |        | 10
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4096
//        |        | spills |  9   spills
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4097
//        V        |        |  8   (pad0 slot for callee)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4098
//      -----------+--------+----> Matcher::_out_arg_limit, unaligned
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4099
//        ^        |  out   |  7
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4100
//        |        |  args  |  6   Holes in outgoing args owned by CALLEE
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4101
//     Owned by    +--------+
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4102
//      CALLEE     | new out|  6   Empty on Intel, window on Sparc
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4103
//        |    new |preserve|      Must be even-aligned.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4104
//        |     SP-+--------+----> Matcher::_new_SP, even aligned
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4105
//        |        |        |
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4106
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4107
// Note 1: Only region 8-11 is determined by the allocator.  Region 0-5 is
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4108
//         known from SELF's arguments and the Java calling convention.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4109
//         Region 6-7 is determined per call site.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4110
// Note 2: If the calling convention leaves holes in the incoming argument
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4111
//         area, those holes are owned by SELF.  Holes in the outgoing area
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4112
//         are owned by the CALLEE.  Holes should not be nessecary in the
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4113
//         incoming area, as the Java calling convention is completely under
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4114
//         the control of the AD file.  Doubles can be sorted and packed to
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4115
//         avoid holes.  Holes in the outgoing arguments may be nessecary for
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4116
//         varargs C calling conventions.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4117
// Note 3: Region 0-3 is even aligned, with pad2 as needed.  Region 3-5 is
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4118
//         even aligned with pad0 as needed.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4119
//         Region 6 is even aligned.  Region 6-7 is NOT even aligned;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4120
//         region 6-11 is even aligned; it may be padded out more so that
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4121
//         the region from SP to FP meets the minimum stack alignment.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4122
// Note 4: For I2C adapters, the incoming FP may not meet the minimum stack
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4123
//         alignment.  Region 11, pad1, may be dynamically extended so that
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4124
//         SP meets the minimum alignment.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4125
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4126
frame
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4127
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4128
  // What direction does stack grow in (assumed to be same for C & Java)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4129
  stack_direction(TOWARDS_LOW);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4130
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4131
  // These three registers define part of the calling convention
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4132
  // between compiled code and the interpreter.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4133
  inline_cache_reg(RAX);                // Inline Cache Register
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4134
  interpreter_method_oop_reg(RBX);      // Method Oop Register when
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4135
                                        // calling interpreter
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4136
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4137
  // Optional: name the operand used by cisc-spilling to access
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4138
  // [stack_pointer + offset]
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4139
  cisc_spilling_operand_name(indOffset32);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4140
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4141
  // Number of stack slots consumed by locking an object
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4142
  sync_stack_slots(2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4143
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4144
  // Compiled code's Frame Pointer
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4145
  frame_pointer(RSP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4146
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4147
  // Interpreter stores its frame pointer in a register which is
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4148
  // stored to the stack by I2CAdaptors.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4149
  // I2CAdaptors convert from interpreted java to compiled java.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4150
  interpreter_frame_pointer(RBP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4151
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4152
  // Stack alignment requirement
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4153
  stack_alignment(StackAlignmentInBytes); // Alignment size in bytes (128-bit -> 16 bytes)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4154
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4155
  // Number of stack slots between incoming argument block and the start of
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4156
  // a new frame.  The PROLOG must add this many slots to the stack.  The
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4157
  // EPILOG must remove this many slots.  amd64 needs two slots for
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4158
  // return address.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4159
  in_preserve_stack_slots(4 + 2 * VerifyStackAtCalls);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4160
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4161
  // Number of outgoing stack slots killed above the out_preserve_stack_slots
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4162
  // for calls to C.  Supports the var-args backing area for register parms.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4163
  varargs_C_out_slots_killed(frame::arg_reg_save_area_bytes/BytesPerInt);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4164
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4165
  // The after-PROLOG location of the return address.  Location of
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4166
  // return address specifies a type (REG or STACK) and a number
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4167
  // representing the register number (i.e. - use a register name) or
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4168
  // stack slot.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4169
  // Ret Addr is on stack in slot 0 if no locks or verification or alignment.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4170
  // Otherwise, it is above the locks and verification slot and alignment word
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4171
  return_addr(STACK - 2 +
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4172
              round_to(2 + 2 * VerifyStackAtCalls +
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4173
                       Compile::current()->fixed_slots(),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4174
                       WordsPerLong * 2));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4175
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4176
  // Body of function which returns an integer array locating
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4177
  // arguments either in registers or in stack slots.  Passed an array
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4178
  // of ideal registers called "sig" and a "length" count.  Stack-slot
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4179
  // offsets are based on outgoing arguments, i.e. a CALLER setting up
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4180
  // arguments for a CALLEE.  Incoming stack arguments are
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4181
  // automatically biased by the preserve_stack_slots field above.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4182
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4183
  calling_convention
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4184
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4185
    // No difference between ingoing/outgoing just pass false
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4186
    SharedRuntime::java_calling_convention(sig_bt, regs, length, false);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4187
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4188
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4189
  c_calling_convention
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4190
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4191
    // This is obviously always outgoing
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4192
    (void) SharedRuntime::c_calling_convention(sig_bt, regs, length);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4193
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4194
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4195
  // Location of compiled Java return values.  Same as C for now.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4196
  return_value
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4197
  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4198
    assert(ideal_reg >= Op_RegI && ideal_reg <= Op_RegL,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4199
           "only return normal values");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4200
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4201
    static const int lo[Op_RegL + 1] = {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4202
      0,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4203
      0,
360
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  4204
      RAX_num,  // Op_RegN
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4205
      RAX_num,  // Op_RegI
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4206
      RAX_num,  // Op_RegP
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4207
      XMM0_num, // Op_RegF
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4208
      XMM0_num, // Op_RegD
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4209
      RAX_num   // Op_RegL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4210
    };
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4211
    static const int hi[Op_RegL + 1] = {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4212
      0,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4213
      0,
360
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  4214
      OptoReg::Bad, // Op_RegN
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4215
      OptoReg::Bad, // Op_RegI
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4216
      RAX_H_num,    // Op_RegP
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4217
      OptoReg::Bad, // Op_RegF
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4218
      XMM0_H_num,   // Op_RegD
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4219
      RAX_H_num     // Op_RegL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4220
    };
360
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  4221
    assert(ARRAY_SIZE(hi) == _last_machine_leaf - 1, "missing type");
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4222
    return OptoRegPair(hi[ideal_reg], lo[ideal_reg]);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4223
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4224
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4225
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4226
//----------ATTRIBUTES---------------------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4227
//----------Operand Attributes-------------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4228
op_attrib op_cost(0);        // Required cost attribute
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4229
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4230
//----------Instruction Attributes---------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4231
ins_attrib ins_cost(100);       // Required cost attribute
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4232
ins_attrib ins_size(8);         // Required size attribute (in bits)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4233
ins_attrib ins_pc_relative(0);  // Required PC Relative flag
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4234
ins_attrib ins_short_branch(0); // Required flag: is this instruction
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4235
                                // a non-matching short branch variant
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4236
                                // of some long branch?
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4237
ins_attrib ins_alignment(1);    // Required alignment attribute (must
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4238
                                // be a power of 2) specifies the
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4239
                                // alignment that some part of the
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4240
                                // instruction (not necessarily the
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4241
                                // start) requires.  If > 1, a
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4242
                                // compute_padding() function must be
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4243
                                // provided for the instruction
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4244
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4245
//----------OPERANDS-----------------------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4246
// Operand definitions must precede instruction definitions for correct parsing
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4247
// in the ADLC because operands constitute user defined types which are used in
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4248
// instruction definitions.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4249
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4250
//----------Simple Operands----------------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4251
// Immediate Operands
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4252
// Integer Immediate
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4253
operand immI()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4254
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4255
  match(ConI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4256
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4257
  op_cost(10);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4258
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4259
  interface(CONST_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4260
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4261
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4262
// Constant for test vs zero
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4263
operand immI0()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4264
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4265
  predicate(n->get_int() == 0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4266
  match(ConI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4267
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4268
  op_cost(0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4269
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4270
  interface(CONST_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4271
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4272
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4273
// Constant for increment
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4274
operand immI1()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4275
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4276
  predicate(n->get_int() == 1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4277
  match(ConI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4278
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4279
  op_cost(0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4280
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4281
  interface(CONST_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4282
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4283
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4284
// Constant for decrement
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4285
operand immI_M1()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4286
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4287
  predicate(n->get_int() == -1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4288
  match(ConI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4289
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4290
  op_cost(0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4291
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4292
  interface(CONST_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4293
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4294
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4295
// Valid scale values for addressing modes
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4296
operand immI2()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4297
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4298
  predicate(0 <= n->get_int() && (n->get_int() <= 3));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4299
  match(ConI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4300
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4301
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4302
  interface(CONST_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4303
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4304
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4305
operand immI8()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4306
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4307
  predicate((-0x80 <= n->get_int()) && (n->get_int() < 0x80));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4308
  match(ConI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4309
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4310
  op_cost(5);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4311
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4312
  interface(CONST_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4313
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4314
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4315
operand immI16()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4316
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4317
  predicate((-32768 <= n->get_int()) && (n->get_int() <= 32767));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4318
  match(ConI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4319
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4320
  op_cost(10);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4321
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4322
  interface(CONST_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4323
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4324
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4325
// Constant for long shifts
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4326
operand immI_32()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4327
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4328
  predicate( n->get_int() == 32 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4329
  match(ConI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4330
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4331
  op_cost(0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4332
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4333
  interface(CONST_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4334
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4335
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4336
// Constant for long shifts
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4337
operand immI_64()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4338
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4339
  predicate( n->get_int() == 64 );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4340
  match(ConI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4341
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4342
  op_cost(0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4343
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4344
  interface(CONST_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4345
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4346
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4347
// Pointer Immediate
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4348
operand immP()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4349
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4350
  match(ConP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4351
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4352
  op_cost(10);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4353
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4354
  interface(CONST_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4355
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4356
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4357
// NULL Pointer Immediate
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4358
operand immP0()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4359
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4360
  predicate(n->get_ptr() == 0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4361
  match(ConP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4362
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4363
  op_cost(5);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4364
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4365
  interface(CONST_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4366
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4367
360
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  4368
// Pointer Immediate
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  4369
operand immN() %{
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  4370
  match(ConN);
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  4371
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  4372
  op_cost(10);
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  4373
  format %{ %}
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  4374
  interface(CONST_INTER);
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  4375
%}
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  4376
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  4377
// NULL Pointer Immediate
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  4378
operand immN0() %{
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  4379
  predicate(n->get_narrowcon() == 0);
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  4380
  match(ConN);
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  4381
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  4382
  op_cost(5);
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  4383
  format %{ %}
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  4384
  interface(CONST_INTER);
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  4385
%}
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  4386
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4387
operand immP31()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4388
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4389
  predicate(!n->as_Type()->type()->isa_oopptr()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4390
            && (n->get_ptr() >> 31) == 0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4391
  match(ConP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4392
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4393
  op_cost(5);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4394
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4395
  interface(CONST_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4396
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4397
360
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  4398
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4399
// Long Immediate
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4400
operand immL()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4401
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4402
  match(ConL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4403
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4404
  op_cost(20);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4405
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4406
  interface(CONST_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4407
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4408
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4409
// Long Immediate 8-bit
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4410
operand immL8()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4411
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4412
  predicate(-0x80L <= n->get_long() && n->get_long() < 0x80L);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4413
  match(ConL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4414
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4415
  op_cost(5);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4416
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4417
  interface(CONST_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4418
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4419
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4420
// Long Immediate 32-bit unsigned
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4421
operand immUL32()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4422
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4423
  predicate(n->get_long() == (unsigned int) (n->get_long()));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4424
  match(ConL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4425
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4426
  op_cost(10);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4427
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4428
  interface(CONST_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4429
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4430
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4431
// Long Immediate 32-bit signed
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4432
operand immL32()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4433
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4434
  predicate(n->get_long() == (int) (n->get_long()));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4435
  match(ConL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4436
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4437
  op_cost(15);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4438
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4439
  interface(CONST_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4440
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4441
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4442
// Long Immediate zero
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4443
operand immL0()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4444
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4445
  predicate(n->get_long() == 0L);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4446
  match(ConL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4447
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4448
  op_cost(10);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4449
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4450
  interface(CONST_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4451
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4452
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4453
// Constant for increment
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4454
operand immL1()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4455
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4456
  predicate(n->get_long() == 1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4457
  match(ConL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4458
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4459
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4460
  interface(CONST_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4461
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4462
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4463
// Constant for decrement
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4464
operand immL_M1()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4465
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4466
  predicate(n->get_long() == -1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4467
  match(ConL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4468
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4469
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4470
  interface(CONST_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4471
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4472
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4473
// Long Immediate: the value 10
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4474
operand immL10()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4475
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4476
  predicate(n->get_long() == 10);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4477
  match(ConL);
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(CONST_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4481
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4482
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4483
// Long immediate from 0 to 127.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4484
// Used for a shorter form of long mul by 10.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4485
operand immL_127()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4486
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4487
  predicate(0 <= n->get_long() && n->get_long() < 0x80);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4488
  match(ConL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4489
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4490
  op_cost(10);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4491
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4492
  interface(CONST_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4493
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4494
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4495
// Long Immediate: low 32-bit mask
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4496
operand immL_32bits()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4497
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4498
  predicate(n->get_long() == 0xFFFFFFFFL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4499
  match(ConL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4500
  op_cost(20);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4501
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4502
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4503
  interface(CONST_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4504
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4505
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4506
// Float Immediate zero
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4507
operand immF0()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4508
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4509
  predicate(jint_cast(n->getf()) == 0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4510
  match(ConF);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4511
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4512
  op_cost(5);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4513
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4514
  interface(CONST_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4515
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4516
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4517
// Float Immediate
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4518
operand immF()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4519
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4520
  match(ConF);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4521
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4522
  op_cost(15);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4523
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4524
  interface(CONST_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4525
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4526
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4527
// Double Immediate zero
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4528
operand immD0()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4529
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4530
  predicate(jlong_cast(n->getd()) == 0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4531
  match(ConD);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4532
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4533
  op_cost(5);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4534
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4535
  interface(CONST_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4536
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4537
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4538
// Double Immediate
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4539
operand immD()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4540
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4541
  match(ConD);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4542
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4543
  op_cost(15);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4544
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4545
  interface(CONST_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4546
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4547
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4548
// Immediates for special shifts (sign extend)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4549
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4550
// Constants for increment
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4551
operand immI_16()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4552
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4553
  predicate(n->get_int() == 16);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4554
  match(ConI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4555
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4556
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4557
  interface(CONST_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4558
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4559
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4560
operand immI_24()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4561
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4562
  predicate(n->get_int() == 24);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4563
  match(ConI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4564
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4565
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4566
  interface(CONST_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4567
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4568
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4569
// Constant for byte-wide masking
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4570
operand immI_255()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4571
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4572
  predicate(n->get_int() == 255);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4573
  match(ConI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4574
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4575
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4576
  interface(CONST_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4577
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4578
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4579
// Constant for short-wide masking
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4580
operand immI_65535()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4581
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4582
  predicate(n->get_int() == 65535);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4583
  match(ConI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4584
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4585
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4586
  interface(CONST_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4587
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4588
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4589
// Constant for byte-wide masking
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4590
operand immL_255()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4591
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4592
  predicate(n->get_long() == 255);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4593
  match(ConL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4594
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4595
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4596
  interface(CONST_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4597
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4598
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4599
// Constant for short-wide masking
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4600
operand immL_65535()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4601
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4602
  predicate(n->get_long() == 65535);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4603
  match(ConL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4604
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4605
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4606
  interface(CONST_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4607
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4608
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4609
// Register Operands
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4610
// Integer Register
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4611
operand rRegI()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4612
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4613
  constraint(ALLOC_IN_RC(int_reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4614
  match(RegI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4615
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4616
  match(rax_RegI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4617
  match(rbx_RegI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4618
  match(rcx_RegI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4619
  match(rdx_RegI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4620
  match(rdi_RegI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4621
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4622
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4623
  interface(REG_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4624
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4625
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4626
// Special Registers
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4627
operand rax_RegI()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4628
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4629
  constraint(ALLOC_IN_RC(int_rax_reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4630
  match(RegI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4631
  match(rRegI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4632
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4633
  format %{ "RAX" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4634
  interface(REG_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4635
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4636
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4637
// Special Registers
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4638
operand rbx_RegI()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4639
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4640
  constraint(ALLOC_IN_RC(int_rbx_reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4641
  match(RegI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4642
  match(rRegI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4643
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4644
  format %{ "RBX" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4645
  interface(REG_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4646
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4647
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4648
operand rcx_RegI()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4649
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4650
  constraint(ALLOC_IN_RC(int_rcx_reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4651
  match(RegI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4652
  match(rRegI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4653
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4654
  format %{ "RCX" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4655
  interface(REG_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4656
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4657
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4658
operand rdx_RegI()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4659
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4660
  constraint(ALLOC_IN_RC(int_rdx_reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4661
  match(RegI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4662
  match(rRegI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4663
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4664
  format %{ "RDX" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4665
  interface(REG_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4666
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4667
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4668
operand rdi_RegI()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4669
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4670
  constraint(ALLOC_IN_RC(int_rdi_reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4671
  match(RegI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4672
  match(rRegI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4673
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4674
  format %{ "RDI" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4675
  interface(REG_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4676
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4677
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4678
operand no_rcx_RegI()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4679
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4680
  constraint(ALLOC_IN_RC(int_no_rcx_reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4681
  match(RegI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4682
  match(rax_RegI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4683
  match(rbx_RegI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4684
  match(rdx_RegI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4685
  match(rdi_RegI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4686
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4687
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4688
  interface(REG_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4689
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4690
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4691
operand no_rax_rdx_RegI()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4692
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4693
  constraint(ALLOC_IN_RC(int_no_rax_rdx_reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4694
  match(RegI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4695
  match(rbx_RegI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4696
  match(rcx_RegI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4697
  match(rdi_RegI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4698
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4699
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4700
  interface(REG_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4701
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4702
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4703
// Pointer Register
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4704
operand any_RegP()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4705
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4706
  constraint(ALLOC_IN_RC(any_reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4707
  match(RegP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4708
  match(rax_RegP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4709
  match(rbx_RegP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4710
  match(rdi_RegP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4711
  match(rsi_RegP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4712
  match(rbp_RegP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4713
  match(r15_RegP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4714
  match(rRegP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4715
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4716
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4717
  interface(REG_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4718
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4719
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4720
operand rRegP()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4721
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4722
  constraint(ALLOC_IN_RC(ptr_reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4723
  match(RegP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4724
  match(rax_RegP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4725
  match(rbx_RegP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4726
  match(rdi_RegP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4727
  match(rsi_RegP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4728
  match(rbp_RegP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4729
  match(r15_RegP);  // See Q&A below about r15_RegP.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4730
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4731
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4732
  interface(REG_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4733
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4734
360
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  4735
operand rRegN() %{
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  4736
  constraint(ALLOC_IN_RC(int_reg));
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  4737
  match(RegN);
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  4738
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  4739
  format %{ %}
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  4740
  interface(REG_INTER);
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  4741
%}
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  4742
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4743
// Question: Why is r15_RegP (the read-only TLS register) a match for rRegP?
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4744
// Answer: Operand match rules govern the DFA as it processes instruction inputs.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4745
// It's fine for an instruction input which expects rRegP to match a r15_RegP.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4746
// The output of an instruction is controlled by the allocator, which respects
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4747
// register class masks, not match rules.  Unless an instruction mentions
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4748
// r15_RegP or any_RegP explicitly as its output, r15 will not be considered
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4749
// by the allocator as an input.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4750
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4751
operand no_rax_RegP()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4752
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4753
  constraint(ALLOC_IN_RC(ptr_no_rax_reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4754
  match(RegP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4755
  match(rbx_RegP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4756
  match(rsi_RegP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4757
  match(rdi_RegP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4758
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4759
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4760
  interface(REG_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4761
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4762
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4763
operand no_rbp_RegP()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4764
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4765
  constraint(ALLOC_IN_RC(ptr_no_rbp_reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4766
  match(RegP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4767
  match(rbx_RegP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4768
  match(rsi_RegP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4769
  match(rdi_RegP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4770
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4771
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4772
  interface(REG_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4773
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4774
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4775
operand no_rax_rbx_RegP()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4776
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4777
  constraint(ALLOC_IN_RC(ptr_no_rax_rbx_reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4778
  match(RegP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4779
  match(rsi_RegP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4780
  match(rdi_RegP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4781
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4782
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4783
  interface(REG_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4784
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4785
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4786
// Special Registers
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4787
// Return a pointer value
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4788
operand rax_RegP()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4789
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4790
  constraint(ALLOC_IN_RC(ptr_rax_reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4791
  match(RegP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4792
  match(rRegP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4793
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4794
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4795
  interface(REG_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4796
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4797
360
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  4798
// Special Registers
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  4799
// Return a compressed pointer value
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  4800
operand rax_RegN()
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  4801
%{
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  4802
  constraint(ALLOC_IN_RC(int_rax_reg));
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  4803
  match(RegN);
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  4804
  match(rRegN);
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  4805
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  4806
  format %{ %}
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  4807
  interface(REG_INTER);
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  4808
%}
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  4809
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4810
// Used in AtomicAdd
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4811
operand rbx_RegP()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4812
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4813
  constraint(ALLOC_IN_RC(ptr_rbx_reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4814
  match(RegP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4815
  match(rRegP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4816
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4817
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4818
  interface(REG_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4819
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4820
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4821
operand rsi_RegP()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4822
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4823
  constraint(ALLOC_IN_RC(ptr_rsi_reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4824
  match(RegP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4825
  match(rRegP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4826
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4827
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4828
  interface(REG_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4829
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4830
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4831
// Used in rep stosq
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4832
operand rdi_RegP()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4833
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4834
  constraint(ALLOC_IN_RC(ptr_rdi_reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4835
  match(RegP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4836
  match(rRegP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4837
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4838
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4839
  interface(REG_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4840
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4841
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4842
operand rbp_RegP()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4843
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4844
  constraint(ALLOC_IN_RC(ptr_rbp_reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4845
  match(RegP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4846
  match(rRegP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4847
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4848
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4849
  interface(REG_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4850
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4851
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4852
operand r15_RegP()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4853
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4854
  constraint(ALLOC_IN_RC(ptr_r15_reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4855
  match(RegP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4856
  match(rRegP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4857
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4858
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4859
  interface(REG_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4860
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4861
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4862
operand rRegL()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4863
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4864
  constraint(ALLOC_IN_RC(long_reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4865
  match(RegL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4866
  match(rax_RegL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4867
  match(rdx_RegL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4868
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4869
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4870
  interface(REG_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4871
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4872
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4873
// Special Registers
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4874
operand no_rax_rdx_RegL()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4875
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4876
  constraint(ALLOC_IN_RC(long_no_rax_rdx_reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4877
  match(RegL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4878
  match(rRegL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4879
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4880
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4881
  interface(REG_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4882
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4883
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4884
operand no_rax_RegL()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4885
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4886
  constraint(ALLOC_IN_RC(long_no_rax_rdx_reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4887
  match(RegL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4888
  match(rRegL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4889
  match(rdx_RegL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4890
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4891
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4892
  interface(REG_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4893
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4894
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4895
operand no_rcx_RegL()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4896
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4897
  constraint(ALLOC_IN_RC(long_no_rcx_reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4898
  match(RegL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4899
  match(rRegL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4900
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4901
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4902
  interface(REG_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4903
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4904
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4905
operand rax_RegL()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4906
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4907
  constraint(ALLOC_IN_RC(long_rax_reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4908
  match(RegL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4909
  match(rRegL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4910
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4911
  format %{ "RAX" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4912
  interface(REG_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4913
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4914
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4915
operand rcx_RegL()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4916
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4917
  constraint(ALLOC_IN_RC(long_rcx_reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4918
  match(RegL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4919
  match(rRegL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4920
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4921
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4922
  interface(REG_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4923
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4924
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4925
operand rdx_RegL()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4926
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4927
  constraint(ALLOC_IN_RC(long_rdx_reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4928
  match(RegL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4929
  match(rRegL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4930
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4931
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4932
  interface(REG_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4933
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4934
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4935
// Flags register, used as output of compare instructions
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4936
operand rFlagsReg()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4937
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4938
  constraint(ALLOC_IN_RC(int_flags));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4939
  match(RegFlags);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4940
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4941
  format %{ "RFLAGS" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4942
  interface(REG_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4943
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4944
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4945
// Flags register, used as output of FLOATING POINT compare instructions
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4946
operand rFlagsRegU()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4947
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4948
  constraint(ALLOC_IN_RC(int_flags));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4949
  match(RegFlags);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4950
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4951
  format %{ "RFLAGS_U" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4952
  interface(REG_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4953
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4954
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  4955
operand rFlagsRegUCF() %{
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  4956
  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
  4957
  match(RegFlags);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  4958
  predicate(false);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  4959
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  4960
  format %{ "RFLAGS_U_CF" %}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  4961
  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
  4962
%}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  4963
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4964
// Float register operands
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4965
operand regF()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4966
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4967
  constraint(ALLOC_IN_RC(float_reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4968
  match(RegF);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4969
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4970
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4971
  interface(REG_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4972
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4973
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4974
// Double register operands
2348
4e71ed4c2709 6761600: Use sse 4.2 in intrinsics
cfang
parents: 2338
diff changeset
  4975
operand regD() 
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4976
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4977
  constraint(ALLOC_IN_RC(double_reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4978
  match(RegD);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4979
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4980
  format %{ %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4981
  interface(REG_INTER);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4982
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4983
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4984
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4985
//----------Memory Operands----------------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4986
// Direct Memory Operand
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4987
// operand direct(immP addr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4988
// %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4989
//   match(addr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4990
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4991
//   format %{ "[$addr]" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4992
//   interface(MEMORY_INTER) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4993
//     base(0xFFFFFFFF);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4994
//     index(0x4);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4995
//     scale(0x0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4996
//     disp($addr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4997
//   %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4998
// %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4999
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5000
// Indirect Memory Operand
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5001
operand indirect(any_RegP reg)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5002
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5003
  constraint(ALLOC_IN_RC(ptr_reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5004
  match(reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5005
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5006
  format %{ "[$reg]" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5007
  interface(MEMORY_INTER) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5008
    base($reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5009
    index(0x4);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5010
    scale(0x0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5011
    disp(0x0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5012
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5013
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5014
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5015
// Indirect Memory Plus Short Offset Operand
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5016
operand indOffset8(any_RegP reg, immL8 off)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5017
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5018
  constraint(ALLOC_IN_RC(ptr_reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5019
  match(AddP reg off);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5020
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5021
  format %{ "[$reg + $off (8-bit)]" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5022
  interface(MEMORY_INTER) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5023
    base($reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5024
    index(0x4);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5025
    scale(0x0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5026
    disp($off);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5027
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5028
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5029
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5030
// Indirect Memory Plus Long Offset Operand
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5031
operand indOffset32(any_RegP reg, immL32 off)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5032
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5033
  constraint(ALLOC_IN_RC(ptr_reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5034
  match(AddP reg off);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5035
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5036
  format %{ "[$reg + $off (32-bit)]" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5037
  interface(MEMORY_INTER) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5038
    base($reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5039
    index(0x4);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5040
    scale(0x0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5041
    disp($off);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5042
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5043
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5044
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5045
// Indirect Memory Plus Index Register Plus Offset Operand
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5046
operand indIndexOffset(any_RegP reg, rRegL lreg, immL32 off)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5047
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5048
  constraint(ALLOC_IN_RC(ptr_reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5049
  match(AddP (AddP reg lreg) off);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5050
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5051
  op_cost(10);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5052
  format %{"[$reg + $off + $lreg]" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5053
  interface(MEMORY_INTER) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5054
    base($reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5055
    index($lreg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5056
    scale(0x0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5057
    disp($off);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5058
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5059
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5060
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5061
// Indirect Memory Plus Index Register Plus Offset Operand
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5062
operand indIndex(any_RegP reg, rRegL lreg)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5063
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5064
  constraint(ALLOC_IN_RC(ptr_reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5065
  match(AddP reg lreg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5066
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5067
  op_cost(10);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5068
  format %{"[$reg + $lreg]" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5069
  interface(MEMORY_INTER) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5070
    base($reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5071
    index($lreg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5072
    scale(0x0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5073
    disp(0x0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5074
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5075
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5076
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5077
// Indirect Memory Times Scale Plus Index Register
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5078
operand indIndexScale(any_RegP reg, rRegL lreg, immI2 scale)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5079
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5080
  constraint(ALLOC_IN_RC(ptr_reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5081
  match(AddP reg (LShiftL lreg scale));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5082
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5083
  op_cost(10);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5084
  format %{"[$reg + $lreg << $scale]" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5085
  interface(MEMORY_INTER) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5086
    base($reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5087
    index($lreg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5088
    scale($scale);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5089
    disp(0x0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5090
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5091
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5092
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5093
// Indirect Memory Times Scale Plus Index Register Plus Offset Operand
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5094
operand indIndexScaleOffset(any_RegP reg, immL32 off, rRegL lreg, immI2 scale)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5095
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5096
  constraint(ALLOC_IN_RC(ptr_reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5097
  match(AddP (AddP reg (LShiftL lreg scale)) off);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5098
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5099
  op_cost(10);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5100
  format %{"[$reg + $off + $lreg << $scale]" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5101
  interface(MEMORY_INTER) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5102
    base($reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5103
    index($lreg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5104
    scale($scale);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5105
    disp($off);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5106
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5107
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5108
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5109
// Indirect Memory Times Scale Plus Positive Index Register Plus Offset Operand
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5110
operand indPosIndexScaleOffset(any_RegP reg, immL32 off, rRegI idx, immI2 scale)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5111
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5112
  constraint(ALLOC_IN_RC(ptr_reg));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5113
  predicate(n->in(2)->in(3)->in(1)->as_Type()->type()->is_long()->_lo >= 0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5114
  match(AddP (AddP reg (LShiftL (ConvI2L idx) scale)) off);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5115
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5116
  op_cost(10);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5117
  format %{"[$reg + $off + $idx << $scale]" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5118
  interface(MEMORY_INTER) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5119
    base($reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5120
    index($idx);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5121
    scale($scale);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5122
    disp($off);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5123
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5124
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5125
2254
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5126
// Indirect Narrow Oop Plus Offset Operand
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5127
// Note: x86 architecture doesn't support "scale * index + offset" without a base
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5128
// we can't free r12 even with Universe::narrow_oop_base() == NULL.
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5129
operand indCompressedOopOffset(rRegN reg, immL32 off) %{
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5130
  predicate(UseCompressedOops && (Universe::narrow_oop_shift() != 0));
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5131
  constraint(ALLOC_IN_RC(ptr_reg));
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5132
  match(AddP (DecodeN reg) off);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5133
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5134
  op_cost(10);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5135
  format %{"[R12 + $reg << 3 + $off] (compressed oop addressing)" %}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5136
  interface(MEMORY_INTER) %{
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5137
    base(0xc); // R12
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5138
    index($reg);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5139
    scale(0x3);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5140
    disp($off);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5141
  %}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5142
%}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5143
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5144
// Indirect Memory Operand
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5145
operand indirectNarrow(rRegN reg)
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5146
%{
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5147
  predicate(Universe::narrow_oop_shift() == 0);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5148
  constraint(ALLOC_IN_RC(ptr_reg));
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5149
  match(DecodeN reg);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5150
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5151
  format %{ "[$reg]" %}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5152
  interface(MEMORY_INTER) %{
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5153
    base($reg);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5154
    index(0x4);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5155
    scale(0x0);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5156
    disp(0x0);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5157
  %}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5158
%}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5159
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5160
// Indirect Memory Plus Short Offset Operand
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5161
operand indOffset8Narrow(rRegN reg, immL8 off)
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5162
%{
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5163
  predicate(Universe::narrow_oop_shift() == 0);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5164
  constraint(ALLOC_IN_RC(ptr_reg));
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5165
  match(AddP (DecodeN reg) off);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5166
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5167
  format %{ "[$reg + $off (8-bit)]" %}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5168
  interface(MEMORY_INTER) %{
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5169
    base($reg);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5170
    index(0x4);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5171
    scale(0x0);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5172
    disp($off);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5173
  %}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5174
%}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5175
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5176
// Indirect Memory Plus Long Offset Operand
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5177
operand indOffset32Narrow(rRegN reg, immL32 off)
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5178
%{
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5179
  predicate(Universe::narrow_oop_shift() == 0);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5180
  constraint(ALLOC_IN_RC(ptr_reg));
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5181
  match(AddP (DecodeN reg) off);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5182
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5183
  format %{ "[$reg + $off (32-bit)]" %}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5184
  interface(MEMORY_INTER) %{
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5185
    base($reg);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5186
    index(0x4);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5187
    scale(0x0);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5188
    disp($off);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5189
  %}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5190
%}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5191
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5192
// Indirect Memory Plus Index Register Plus Offset Operand
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5193
operand indIndexOffsetNarrow(rRegN reg, rRegL lreg, immL32 off)
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5194
%{
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5195
  predicate(Universe::narrow_oop_shift() == 0);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5196
  constraint(ALLOC_IN_RC(ptr_reg));
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5197
  match(AddP (AddP (DecodeN reg) lreg) off);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5198
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5199
  op_cost(10);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5200
  format %{"[$reg + $off + $lreg]" %}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5201
  interface(MEMORY_INTER) %{
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5202
    base($reg);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5203
    index($lreg);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5204
    scale(0x0);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5205
    disp($off);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5206
  %}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5207
%}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5208
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5209
// Indirect Memory Plus Index Register Plus Offset Operand
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5210
operand indIndexNarrow(rRegN reg, rRegL lreg)
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5211
%{
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5212
  predicate(Universe::narrow_oop_shift() == 0);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5213
  constraint(ALLOC_IN_RC(ptr_reg));
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5214
  match(AddP (DecodeN reg) lreg);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5215
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5216
  op_cost(10);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5217
  format %{"[$reg + $lreg]" %}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5218
  interface(MEMORY_INTER) %{
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5219
    base($reg);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5220
    index($lreg);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5221
    scale(0x0);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5222
    disp(0x0);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5223
  %}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5224
%}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5225
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5226
// Indirect Memory Times Scale Plus Index Register
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5227
operand indIndexScaleNarrow(rRegN reg, rRegL lreg, immI2 scale)
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5228
%{
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5229
  predicate(Universe::narrow_oop_shift() == 0);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5230
  constraint(ALLOC_IN_RC(ptr_reg));
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5231
  match(AddP (DecodeN reg) (LShiftL lreg scale));
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5232
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5233
  op_cost(10);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5234
  format %{"[$reg + $lreg << $scale]" %}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5235
  interface(MEMORY_INTER) %{
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5236
    base($reg);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5237
    index($lreg);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5238
    scale($scale);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5239
    disp(0x0);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5240
  %}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5241
%}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5242
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5243
// Indirect Memory Times Scale Plus Index Register Plus Offset Operand
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5244
operand indIndexScaleOffsetNarrow(rRegN reg, immL32 off, rRegL lreg, immI2 scale)
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5245
%{
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5246
  predicate(Universe::narrow_oop_shift() == 0);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5247
  constraint(ALLOC_IN_RC(ptr_reg));
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5248
  match(AddP (AddP (DecodeN reg) (LShiftL lreg scale)) off);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5249
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5250
  op_cost(10);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5251
  format %{"[$reg + $off + $lreg << $scale]" %}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5252
  interface(MEMORY_INTER) %{
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5253
    base($reg);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5254
    index($lreg);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5255
    scale($scale);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5256
    disp($off);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5257
  %}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5258
%}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5259
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5260
// Indirect Memory Times Scale Plus Positive Index Register Plus Offset Operand
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5261
operand indPosIndexScaleOffsetNarrow(rRegN reg, immL32 off, rRegI idx, immI2 scale)
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5262
%{
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5263
  constraint(ALLOC_IN_RC(ptr_reg));
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5264
  predicate(Universe::narrow_oop_shift() == 0 && n->in(2)->in(3)->in(1)->as_Type()->type()->is_long()->_lo >= 0);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5265
  match(AddP (AddP (DecodeN reg) (LShiftL (ConvI2L idx) scale)) off);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5266
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5267
  op_cost(10);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5268
  format %{"[$reg + $off + $idx << $scale]" %}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5269
  interface(MEMORY_INTER) %{
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5270
    base($reg);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5271
    index($idx);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5272
    scale($scale);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5273
    disp($off);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5274
  %}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5275
%}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5276
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5277
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5278
//----------Special Memory Operands--------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5279
// Stack Slot Operand - This operand is used for loading and storing temporary
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5280
//                      values on the stack where a match requires a value to
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5281
//                      flow through memory.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5282
operand stackSlotP(sRegP reg)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5283
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5284
  constraint(ALLOC_IN_RC(stack_slots));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5285
  // No match rule because this operand is only generated in matching
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5286
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5287
  format %{ "[$reg]" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5288
  interface(MEMORY_INTER) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5289
    base(0x4);   // RSP
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5290
    index(0x4);  // No Index
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5291
    scale(0x0);  // No Scale
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5292
    disp($reg);  // Stack Offset
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5293
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5294
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5295
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5296
operand stackSlotI(sRegI reg)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5297
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5298
  constraint(ALLOC_IN_RC(stack_slots));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5299
  // No match rule because this operand is only generated in matching
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5300
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5301
  format %{ "[$reg]" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5302
  interface(MEMORY_INTER) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5303
    base(0x4);   // RSP
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5304
    index(0x4);  // No Index
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5305
    scale(0x0);  // No Scale
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5306
    disp($reg);  // Stack Offset
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5307
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5308
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5309
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5310
operand stackSlotF(sRegF reg)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5311
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5312
  constraint(ALLOC_IN_RC(stack_slots));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5313
  // No match rule because this operand is only generated in matching
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5314
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5315
  format %{ "[$reg]" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5316
  interface(MEMORY_INTER) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5317
    base(0x4);   // RSP
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5318
    index(0x4);  // No Index
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5319
    scale(0x0);  // No Scale
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5320
    disp($reg);  // Stack Offset
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5321
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5322
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5323
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5324
operand stackSlotD(sRegD reg)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5325
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5326
  constraint(ALLOC_IN_RC(stack_slots));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5327
  // No match rule because this operand is only generated in matching
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5328
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5329
  format %{ "[$reg]" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5330
  interface(MEMORY_INTER) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5331
    base(0x4);   // RSP
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5332
    index(0x4);  // No Index
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5333
    scale(0x0);  // No Scale
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5334
    disp($reg);  // Stack Offset
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5335
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5336
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5337
operand stackSlotL(sRegL reg)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5338
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5339
  constraint(ALLOC_IN_RC(stack_slots));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5340
  // No match rule because this operand is only generated in matching
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5341
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5342
  format %{ "[$reg]" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5343
  interface(MEMORY_INTER) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5344
    base(0x4);   // RSP
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5345
    index(0x4);  // No Index
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5346
    scale(0x0);  // No Scale
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5347
    disp($reg);  // Stack Offset
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5348
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5349
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5350
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5351
//----------Conditional Branch Operands----------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5352
// Comparison Op  - This is the operation of the comparison, and is limited to
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5353
//                  the following set of codes:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5354
//                  L (<), LE (<=), G (>), GE (>=), E (==), NE (!=)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5355
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5356
// Other attributes of the comparison, such as unsignedness, are specified
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5357
// by the comparison instruction that sets a condition code flags register.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5358
// That result is represented by a flags operand whose subtype is appropriate
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5359
// to the unsignedness (etc.) of the comparison.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5360
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5361
// Later, the instruction which matches both the Comparison Op (a Bool) and
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5362
// the flags (produced by the Cmp) specifies the coding of the comparison op
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5363
// by matching a specific subtype of Bool operand below, such as cmpOpU.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5364
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5365
// Comparision Code
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5366
operand cmpOp()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5367
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5368
  match(Bool);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5369
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5370
  format %{ "" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5371
  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
  5372
    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
  5373
    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
  5374
    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
  5375
    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
  5376
    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
  5377
    greater(0xF, "g");
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5378
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5379
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5380
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5381
// Comparison Code, unsigned compare.  Used by FP also, with
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5382
// C2 (unordered) turned into GT or LT already.  The other bits
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5383
// C0 and C3 are turned into Carry & Zero flags.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5384
operand cmpOpU()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5385
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5386
  match(Bool);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5387
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5388
  format %{ "" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5389
  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
  5390
    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
  5391
    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
  5392
    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
  5393
    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
  5394
    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
  5395
    greater(0x7, "nbe");
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  5396
  %}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  5397
%}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  5398
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  5399
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  5400
// 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
  5401
operand cmpOpUCF() %{
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  5402
  match(Bool);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  5403
  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
  5404
            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
  5405
            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
  5406
            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
  5407
  format %{ "" %}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  5408
  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
  5409
    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
  5410
    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
  5411
    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
  5412
    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
  5413
    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
  5414
    greater(0x7, "nbe");
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  5415
  %}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  5416
%}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  5417
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  5418
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  5419
// 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
  5420
operand cmpOpUCF2() %{
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  5421
  match(Bool);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  5422
  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
  5423
            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
  5424
  format %{ "" %}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  5425
  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
  5426
    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
  5427
    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
  5428
    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
  5429
    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
  5430
    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
  5431
    greater(0x7, "nbe");
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5432
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5433
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5434
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5435
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5436
//----------OPERAND CLASSES----------------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5437
// Operand Classes are groups of operands that are used as to simplify
2131
98f9cef66a34 6810672: Comment typos
twisti
parents: 2033
diff changeset
  5438
// instruction definitions by not requiring the AD writer to specify separate
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5439
// instructions for every form of operand when the instruction accepts
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5440
// multiple operand types with the same basic encoding and format.  The classic
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5441
// case of this is memory operands.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5442
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5443
opclass memory(indirect, indOffset8, indOffset32, indIndexOffset, indIndex,
360
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  5444
               indIndexScale, indIndexScaleOffset, indPosIndexScaleOffset,
2254
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5445
               indCompressedOopOffset,
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5446
               indirectNarrow, indOffset8Narrow, indOffset32Narrow,
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5447
               indIndexOffsetNarrow, indIndexNarrow, indIndexScaleNarrow,
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  5448
               indIndexScaleOffsetNarrow, indPosIndexScaleOffsetNarrow);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5449
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5450
//----------PIPELINE-----------------------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5451
// Rules which define the behavior of the target architectures pipeline.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5452
pipeline %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5453
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5454
//----------ATTRIBUTES---------------------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5455
attributes %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5456
  variable_size_instructions;        // Fixed size instructions
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5457
  max_instructions_per_bundle = 3;   // Up to 3 instructions per bundle
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5458
  instruction_unit_size = 1;         // An instruction is 1 bytes long
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5459
  instruction_fetch_unit_size = 16;  // The processor fetches one line
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5460
  instruction_fetch_units = 1;       // of 16 bytes
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5461
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5462
  // List of nop instructions
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5463
  nops( MachNop );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5464
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5465
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5466
//----------RESOURCES----------------------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5467
// Resources are the functional units available to the machine
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5468
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5469
// Generic P2/P3 pipeline
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5470
// 3 decoders, only D0 handles big operands; a "bundle" is the limit of
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5471
// 3 instructions decoded per cycle.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5472
// 2 load/store ops per cycle, 1 branch, 1 FPU,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5473
// 3 ALU op, only ALU0 handles mul instructions.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5474
resources( D0, D1, D2, DECODE = D0 | D1 | D2,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5475
           MS0, MS1, MS2, MEM = MS0 | MS1 | MS2,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5476
           BR, FPU,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5477
           ALU0, ALU1, ALU2, ALU = ALU0 | ALU1 | ALU2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5478
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5479
//----------PIPELINE DESCRIPTION-----------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5480
// Pipeline Description specifies the stages in the machine's pipeline
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5481
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5482
// Generic P2/P3 pipeline
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5483
pipe_desc(S0, S1, S2, S3, S4, S5);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5484
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5485
//----------PIPELINE CLASSES---------------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5486
// Pipeline Classes describe the stages in which input and output are
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5487
// referenced by the hardware pipeline.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5488
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5489
// Naming convention: ialu or fpu
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5490
// Then: _reg
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5491
// Then: _reg if there is a 2nd register
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5492
// Then: _long if it's a pair of instructions implementing a long
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5493
// Then: _fat if it requires the big decoder
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5494
//   Or: _mem if it requires the big decoder and a memory unit.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5495
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5496
// Integer ALU reg operation
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5497
pipe_class ialu_reg(rRegI dst)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5498
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5499
    single_instruction;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5500
    dst    : S4(write);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5501
    dst    : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5502
    DECODE : S0;        // any decoder
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5503
    ALU    : S3;        // any alu
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5504
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5505
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5506
// Long ALU reg operation
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5507
pipe_class ialu_reg_long(rRegL dst)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5508
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5509
    instruction_count(2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5510
    dst    : S4(write);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5511
    dst    : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5512
    DECODE : S0(2);     // any 2 decoders
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5513
    ALU    : S3(2);     // both alus
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5514
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5515
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5516
// Integer ALU reg operation using big decoder
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5517
pipe_class ialu_reg_fat(rRegI dst)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5518
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5519
    single_instruction;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5520
    dst    : S4(write);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5521
    dst    : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5522
    D0     : S0;        // big decoder only
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5523
    ALU    : S3;        // any alu
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5524
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5525
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5526
// Long ALU reg operation using big decoder
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5527
pipe_class ialu_reg_long_fat(rRegL dst)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5528
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5529
    instruction_count(2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5530
    dst    : S4(write);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5531
    dst    : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5532
    D0     : S0(2);     // big decoder only; twice
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5533
    ALU    : S3(2);     // any 2 alus
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5534
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5535
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5536
// Integer ALU reg-reg operation
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5537
pipe_class ialu_reg_reg(rRegI dst, rRegI src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5538
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5539
    single_instruction;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5540
    dst    : S4(write);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5541
    src    : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5542
    DECODE : S0;        // any decoder
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5543
    ALU    : S3;        // any alu
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5544
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5545
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5546
// Long ALU reg-reg operation
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5547
pipe_class ialu_reg_reg_long(rRegL dst, rRegL src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5548
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5549
    instruction_count(2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5550
    dst    : S4(write);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5551
    src    : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5552
    DECODE : S0(2);     // any 2 decoders
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5553
    ALU    : S3(2);     // both alus
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5554
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5555
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5556
// Integer ALU reg-reg operation
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5557
pipe_class ialu_reg_reg_fat(rRegI dst, memory src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5558
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5559
    single_instruction;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5560
    dst    : S4(write);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5561
    src    : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5562
    D0     : S0;        // big decoder only
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5563
    ALU    : S3;        // any alu
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5564
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5565
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5566
// Long ALU reg-reg operation
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5567
pipe_class ialu_reg_reg_long_fat(rRegL dst, rRegL src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5568
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5569
    instruction_count(2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5570
    dst    : S4(write);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5571
    src    : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5572
    D0     : S0(2);     // big decoder only; twice
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5573
    ALU    : S3(2);     // both alus
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5574
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5575
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5576
// Integer ALU reg-mem operation
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5577
pipe_class ialu_reg_mem(rRegI dst, memory mem)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5578
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5579
    single_instruction;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5580
    dst    : S5(write);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5581
    mem    : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5582
    D0     : S0;        // big decoder only
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5583
    ALU    : S4;        // any alu
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5584
    MEM    : S3;        // any mem
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5585
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5586
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5587
// Integer mem operation (prefetch)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5588
pipe_class ialu_mem(memory mem)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5589
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5590
    single_instruction;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5591
    mem    : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5592
    D0     : S0;        // big decoder only
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5593
    MEM    : S3;        // any mem
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5594
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5595
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5596
// Integer Store to Memory
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5597
pipe_class ialu_mem_reg(memory mem, rRegI src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5598
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5599
    single_instruction;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5600
    mem    : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5601
    src    : S5(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5602
    D0     : S0;        // big decoder only
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5603
    ALU    : S4;        // any alu
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5604
    MEM    : S3;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5605
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5606
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5607
// // Long Store to Memory
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5608
// pipe_class ialu_mem_long_reg(memory mem, rRegL src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5609
// %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5610
//     instruction_count(2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5611
//     mem    : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5612
//     src    : S5(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5613
//     D0     : S0(2);          // big decoder only; twice
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5614
//     ALU    : S4(2);     // any 2 alus
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5615
//     MEM    : S3(2);  // Both mems
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5616
// %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5617
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5618
// Integer Store to Memory
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5619
pipe_class ialu_mem_imm(memory mem)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5620
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5621
    single_instruction;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5622
    mem    : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5623
    D0     : S0;        // big decoder only
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5624
    ALU    : S4;        // any alu
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5625
    MEM    : S3;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5626
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5627
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5628
// Integer ALU0 reg-reg operation
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5629
pipe_class ialu_reg_reg_alu0(rRegI dst, rRegI src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5630
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5631
    single_instruction;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5632
    dst    : S4(write);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5633
    src    : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5634
    D0     : S0;        // Big decoder only
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5635
    ALU0   : S3;        // only alu0
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5636
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5637
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5638
// Integer ALU0 reg-mem operation
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5639
pipe_class ialu_reg_mem_alu0(rRegI dst, memory mem)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5640
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5641
    single_instruction;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5642
    dst    : S5(write);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5643
    mem    : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5644
    D0     : S0;        // big decoder only
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5645
    ALU0   : S4;        // ALU0 only
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5646
    MEM    : S3;        // any mem
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5647
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5648
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5649
// Integer ALU reg-reg operation
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5650
pipe_class ialu_cr_reg_reg(rFlagsReg cr, rRegI src1, rRegI src2)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5651
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5652
    single_instruction;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5653
    cr     : S4(write);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5654
    src1   : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5655
    src2   : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5656
    DECODE : S0;        // any decoder
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5657
    ALU    : S3;        // any alu
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5658
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5659
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5660
// Integer ALU reg-imm operation
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5661
pipe_class ialu_cr_reg_imm(rFlagsReg cr, rRegI src1)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5662
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5663
    single_instruction;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5664
    cr     : S4(write);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5665
    src1   : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5666
    DECODE : S0;        // any decoder
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5667
    ALU    : S3;        // any alu
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5668
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5669
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5670
// Integer ALU reg-mem operation
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5671
pipe_class ialu_cr_reg_mem(rFlagsReg cr, rRegI src1, memory src2)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5672
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5673
    single_instruction;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5674
    cr     : S4(write);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5675
    src1   : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5676
    src2   : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5677
    D0     : S0;        // big decoder only
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5678
    ALU    : S4;        // any alu
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5679
    MEM    : S3;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5680
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5681
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5682
// Conditional move reg-reg
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5683
pipe_class pipe_cmplt( rRegI p, rRegI q, rRegI y)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5684
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5685
    instruction_count(4);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5686
    y      : S4(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5687
    q      : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5688
    p      : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5689
    DECODE : S0(4);     // any decoder
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5690
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5691
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5692
// Conditional move reg-reg
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5693
pipe_class pipe_cmov_reg( rRegI dst, rRegI src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5694
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5695
    single_instruction;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5696
    dst    : S4(write);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5697
    src    : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5698
    cr     : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5699
    DECODE : S0;        // any decoder
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5700
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5701
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5702
// Conditional move reg-mem
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5703
pipe_class pipe_cmov_mem( rFlagsReg cr, rRegI dst, memory src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5704
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5705
    single_instruction;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5706
    dst    : S4(write);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5707
    src    : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5708
    cr     : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5709
    DECODE : S0;        // any decoder
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5710
    MEM    : S3;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5711
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5712
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5713
// Conditional move reg-reg long
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5714
pipe_class pipe_cmov_reg_long( rFlagsReg cr, rRegL dst, rRegL src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5715
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5716
    single_instruction;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5717
    dst    : S4(write);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5718
    src    : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5719
    cr     : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5720
    DECODE : S0(2);     // any 2 decoders
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5721
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5722
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5723
// XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5724
// // Conditional move double reg-reg
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5725
// pipe_class pipe_cmovD_reg( rFlagsReg cr, regDPR1 dst, regD src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5726
// %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5727
//     single_instruction;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5728
//     dst    : S4(write);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5729
//     src    : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5730
//     cr     : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5731
//     DECODE : S0;     // any decoder
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5732
// %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5733
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5734
// Float reg-reg operation
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5735
pipe_class fpu_reg(regD dst)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5736
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5737
    instruction_count(2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5738
    dst    : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5739
    DECODE : S0(2);     // any 2 decoders
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5740
    FPU    : S3;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5741
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5742
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5743
// Float reg-reg operation
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5744
pipe_class fpu_reg_reg(regD dst, regD src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5745
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5746
    instruction_count(2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5747
    dst    : S4(write);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5748
    src    : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5749
    DECODE : S0(2);     // any 2 decoders
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5750
    FPU    : S3;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5751
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5752
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5753
// Float reg-reg operation
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5754
pipe_class fpu_reg_reg_reg(regD dst, regD src1, regD src2)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5755
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5756
    instruction_count(3);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5757
    dst    : S4(write);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5758
    src1   : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5759
    src2   : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5760
    DECODE : S0(3);     // any 3 decoders
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5761
    FPU    : S3(2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5762
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5763
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5764
// Float reg-reg operation
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5765
pipe_class fpu_reg_reg_reg_reg(regD dst, regD src1, regD src2, regD src3)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5766
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5767
    instruction_count(4);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5768
    dst    : S4(write);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5769
    src1   : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5770
    src2   : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5771
    src3   : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5772
    DECODE : S0(4);     // any 3 decoders
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5773
    FPU    : S3(2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5774
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5775
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5776
// Float reg-reg operation
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5777
pipe_class fpu_reg_mem_reg_reg(regD dst, memory src1, regD src2, regD src3)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5778
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5779
    instruction_count(4);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5780
    dst    : S4(write);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5781
    src1   : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5782
    src2   : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5783
    src3   : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5784
    DECODE : S1(3);     // any 3 decoders
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5785
    D0     : S0;        // Big decoder only
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5786
    FPU    : S3(2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5787
    MEM    : S3;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5788
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5789
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5790
// Float reg-mem operation
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5791
pipe_class fpu_reg_mem(regD dst, memory mem)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5792
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5793
    instruction_count(2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5794
    dst    : S5(write);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5795
    mem    : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5796
    D0     : S0;        // big decoder only
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5797
    DECODE : S1;        // any decoder for FPU POP
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5798
    FPU    : S4;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5799
    MEM    : S3;        // any mem
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5800
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5801
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5802
// Float reg-mem operation
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5803
pipe_class fpu_reg_reg_mem(regD dst, regD src1, memory mem)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5804
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5805
    instruction_count(3);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5806
    dst    : S5(write);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5807
    src1   : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5808
    mem    : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5809
    D0     : S0;        // big decoder only
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5810
    DECODE : S1(2);     // any decoder for FPU POP
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5811
    FPU    : S4;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5812
    MEM    : S3;        // any mem
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5813
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5814
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5815
// Float mem-reg operation
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5816
pipe_class fpu_mem_reg(memory mem, regD src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5817
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5818
    instruction_count(2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5819
    src    : S5(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5820
    mem    : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5821
    DECODE : S0;        // any decoder for FPU PUSH
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5822
    D0     : S1;        // big decoder only
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5823
    FPU    : S4;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5824
    MEM    : S3;        // any mem
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5825
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5826
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5827
pipe_class fpu_mem_reg_reg(memory mem, regD src1, regD src2)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5828
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5829
    instruction_count(3);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5830
    src1   : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5831
    src2   : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5832
    mem    : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5833
    DECODE : S0(2);     // any decoder for FPU PUSH
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5834
    D0     : S1;        // big decoder only
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5835
    FPU    : S4;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5836
    MEM    : S3;        // any mem
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5837
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5838
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5839
pipe_class fpu_mem_reg_mem(memory mem, regD src1, memory src2)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5840
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5841
    instruction_count(3);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5842
    src1   : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5843
    src2   : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5844
    mem    : S4(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5845
    DECODE : S0;        // any decoder for FPU PUSH
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5846
    D0     : S0(2);     // big decoder only
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5847
    FPU    : S4;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5848
    MEM    : S3(2);     // any mem
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5849
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5850
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5851
pipe_class fpu_mem_mem(memory dst, memory src1)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5852
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5853
    instruction_count(2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5854
    src1   : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5855
    dst    : S4(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5856
    D0     : S0(2);     // big decoder only
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5857
    MEM    : S3(2);     // any mem
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5858
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5859
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5860
pipe_class fpu_mem_mem_mem(memory dst, memory src1, memory src2)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5861
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5862
    instruction_count(3);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5863
    src1   : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5864
    src2   : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5865
    dst    : S4(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5866
    D0     : S0(3);     // big decoder only
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5867
    FPU    : S4;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5868
    MEM    : S3(3);     // any mem
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5869
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5870
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5871
pipe_class fpu_mem_reg_con(memory mem, regD src1)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5872
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5873
    instruction_count(3);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5874
    src1   : S4(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5875
    mem    : S4(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5876
    DECODE : S0;        // any decoder for FPU PUSH
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5877
    D0     : S0(2);     // big decoder only
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5878
    FPU    : S4;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5879
    MEM    : S3(2);     // any mem
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5880
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5881
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5882
// Float load constant
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5883
pipe_class fpu_reg_con(regD dst)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5884
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5885
    instruction_count(2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5886
    dst    : S5(write);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5887
    D0     : S0;        // big decoder only for the load
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5888
    DECODE : S1;        // any decoder for FPU POP
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5889
    FPU    : S4;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5890
    MEM    : S3;        // any mem
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5891
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5892
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5893
// Float load constant
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5894
pipe_class fpu_reg_reg_con(regD dst, regD src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5895
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5896
    instruction_count(3);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5897
    dst    : S5(write);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5898
    src    : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5899
    D0     : S0;        // big decoder only for the load
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5900
    DECODE : S1(2);     // any decoder for FPU POP
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5901
    FPU    : S4;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5902
    MEM    : S3;        // any mem
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5903
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5904
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5905
// UnConditional branch
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5906
pipe_class pipe_jmp(label labl)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5907
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5908
    single_instruction;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5909
    BR   : S3;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5910
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5911
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5912
// Conditional branch
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5913
pipe_class pipe_jcc(cmpOp cmp, rFlagsReg cr, label labl)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5914
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5915
    single_instruction;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5916
    cr    : S1(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5917
    BR    : S3;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5918
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5919
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5920
// Allocation idiom
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5921
pipe_class pipe_cmpxchg(rRegP dst, rRegP heap_ptr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5922
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5923
    instruction_count(1); force_serialization;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5924
    fixed_latency(6);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5925
    heap_ptr : S3(read);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5926
    DECODE   : S0(3);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5927
    D0       : S2;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5928
    MEM      : S3;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5929
    ALU      : S3(2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5930
    dst      : S5(write);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5931
    BR       : S5;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5932
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5933
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5934
// Generic big/slow expanded idiom
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5935
pipe_class pipe_slow()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5936
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5937
    instruction_count(10); multiple_bundles; force_serialization;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5938
    fixed_latency(100);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5939
    D0  : S0(2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5940
    MEM : S3(2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5941
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5942
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5943
// The real do-nothing guy
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5944
pipe_class empty()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5945
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5946
    instruction_count(0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5947
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5948
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5949
// Define the class for the Nop node
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5950
define
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5951
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5952
   MachNop = empty;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5953
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5954
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5955
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5956
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5957
//----------INSTRUCTIONS-------------------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5958
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5959
// match      -- States which machine-independent subtree may be replaced
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5960
//               by this instruction.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5961
// ins_cost   -- The estimated cost of this instruction is used by instruction
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5962
//               selection to identify a minimum cost tree of machine
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5963
//               instructions that matches a tree of machine-independent
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5964
//               instructions.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5965
// format     -- A string providing the disassembly for this instruction.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5966
//               The value of an instruction's operand may be inserted
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5967
//               by referring to it with a '$' prefix.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5968
// opcode     -- Three instruction opcodes may be provided.  These are referred
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5969
//               to within an encode class as $primary, $secondary, and $tertiary
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5970
//               rrspectively.  The primary opcode is commonly used to
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5971
//               indicate the type of machine instruction, while secondary
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5972
//               and tertiary are often used for prefix options or addressing
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5973
//               modes.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5974
// ins_encode -- A list of encode classes with parameters. The encode class
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5975
//               name must have been defined in an 'enc_class' specification
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5976
//               in the encode section of the architecture description.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5977
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5978
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5979
//----------Load/Store/Move Instructions---------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5980
//----------Load Instructions--------------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5981
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5982
// Load Byte (8 bit signed)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5983
instruct loadB(rRegI dst, memory mem)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5984
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5985
  match(Set dst (LoadB mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5986
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5987
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5988
  format %{ "movsbl  $dst, $mem\t# byte" %}
2150
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5989
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5990
  ins_encode %{
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5991
    __ movsbl($dst$$Register, $mem$$Address);
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5992
  %}
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5993
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5994
  ins_pipe(ialu_reg_mem);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5995
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  5996
2150
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5997
// Load Byte (8 bit signed) into Long Register
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5998
instruct loadB2L(rRegL dst, memory mem)
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  5999
%{
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6000
  match(Set dst (ConvI2L (LoadB mem)));
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6001
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6002
  ins_cost(125);
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6003
  format %{ "movsbq  $dst, $mem\t# byte -> long" %}
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6004
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6005
  ins_encode %{
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6006
    __ movsbq($dst$$Register, $mem$$Address);
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6007
  %}
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6008
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6009
  ins_pipe(ialu_reg_mem);
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6010
%}
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6011
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6012
// Load Unsigned Byte (8 bit UNsigned)
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6013
instruct loadUB(rRegI dst, memory mem)
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6014
%{
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6015
  match(Set dst (LoadUB mem));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6016
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6017
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6018
  format %{ "movzbl  $dst, $mem\t# ubyte" %}
2150
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6019
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6020
  ins_encode %{
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6021
    __ movzbl($dst$$Register, $mem$$Address);
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6022
  %}
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6023
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6024
  ins_pipe(ialu_reg_mem);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6025
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6026
2150
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6027
// Load Unsigned Byte (8 bit UNsigned) into Long Register
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6028
instruct loadUB2L(rRegL dst, memory mem)
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6029
%{
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6030
  match(Set dst (ConvI2L (LoadUB mem)));
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6031
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6032
  ins_cost(125);
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6033
  format %{ "movzbq  $dst, $mem\t# ubyte -> long" %}
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6034
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6035
  ins_encode %{
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6036
    __ movzbq($dst$$Register, $mem$$Address);
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6037
  %}
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6038
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6039
  ins_pipe(ialu_reg_mem);
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6040
%}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6041
3177
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6042
// Load Unsigned Byte (8 bit UNsigned) with a 8-bit mask into Long Register
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6043
instruct loadUB2L_immI8(rRegL dst, memory mem, immI8 mask, rFlagsReg cr) %{
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6044
  match(Set dst (ConvI2L (AndI (LoadUB mem) mask)));
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6045
  effect(KILL cr);
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6046
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6047
  format %{ "movzbq  $dst, $mem\t# ubyte & 8-bit mask -> long\n\t"
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6048
            "andl    $dst, $mask" %}
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6049
  ins_encode %{
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6050
    Register Rdst = $dst$$Register;
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6051
    __ movzbq(Rdst, $mem$$Address);
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6052
    __ andl(Rdst, $mask$$constant);
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6053
  %}
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6054
  ins_pipe(ialu_reg_mem);
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6055
%}
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6056
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6057
// Load Short (16 bit signed)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6058
instruct loadS(rRegI dst, memory mem)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6059
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6060
  match(Set dst (LoadS mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6061
2150
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6062
  ins_cost(125);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6063
  format %{ "movswl $dst, $mem\t# short" %}
2150
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6064
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6065
  ins_encode %{
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6066
    __ movswl($dst$$Register, $mem$$Address);
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6067
  %}
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6068
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6069
  ins_pipe(ialu_reg_mem);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6070
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6071
2872
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6072
// Load Short (16 bit signed) to Byte (8 bit signed)
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6073
instruct loadS2B(rRegI dst, memory mem, immI_24 twentyfour) %{
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6074
  match(Set dst (RShiftI (LShiftI (LoadS mem) twentyfour) twentyfour));
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6075
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6076
  ins_cost(125);
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6077
  format %{ "movsbl $dst, $mem\t# short -> byte" %}
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6078
  ins_encode %{
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6079
    __ movsbl($dst$$Register, $mem$$Address);
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6080
  %}
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6081
  ins_pipe(ialu_reg_mem);
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6082
%}
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6083
2150
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6084
// Load Short (16 bit signed) into Long Register
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6085
instruct loadS2L(rRegL dst, memory mem)
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6086
%{
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6087
  match(Set dst (ConvI2L (LoadS mem)));
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6088
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6089
  ins_cost(125);
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6090
  format %{ "movswq $dst, $mem\t# short -> long" %}
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6091
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6092
  ins_encode %{
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6093
    __ movswq($dst$$Register, $mem$$Address);
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6094
  %}
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6095
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6096
  ins_pipe(ialu_reg_mem);
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6097
%}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6098
2022
28ce8115a91d 6796746: rename LoadC (char) opcode class to LoadUS (unsigned short)
twisti
parents: 1500
diff changeset
  6099
// Load Unsigned Short/Char (16 bit UNsigned)
28ce8115a91d 6796746: rename LoadC (char) opcode class to LoadUS (unsigned short)
twisti
parents: 1500
diff changeset
  6100
instruct loadUS(rRegI dst, memory mem)
28ce8115a91d 6796746: rename LoadC (char) opcode class to LoadUS (unsigned short)
twisti
parents: 1500
diff changeset
  6101
%{
28ce8115a91d 6796746: rename LoadC (char) opcode class to LoadUS (unsigned short)
twisti
parents: 1500
diff changeset
  6102
  match(Set dst (LoadUS mem));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6103
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6104
  ins_cost(125);
2022
28ce8115a91d 6796746: rename LoadC (char) opcode class to LoadUS (unsigned short)
twisti
parents: 1500
diff changeset
  6105
  format %{ "movzwl  $dst, $mem\t# ushort/char" %}
2150
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6106
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6107
  ins_encode %{
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6108
    __ movzwl($dst$$Register, $mem$$Address);
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6109
  %}
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6110
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6111
  ins_pipe(ialu_reg_mem);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6112
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6113
2872
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6114
// Load Unsigned Short/Char (16 bit UNsigned) to Byte (8 bit signed)
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6115
instruct loadUS2B(rRegI dst, memory mem, immI_24 twentyfour) %{
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6116
  match(Set dst (RShiftI (LShiftI (LoadUS mem) twentyfour) twentyfour));
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6117
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6118
  ins_cost(125);
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6119
  format %{ "movsbl $dst, $mem\t# ushort -> byte" %}
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6120
  ins_encode %{
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6121
    __ movsbl($dst$$Register, $mem$$Address);
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6122
  %}
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6123
  ins_pipe(ialu_reg_mem);
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6124
%}
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6125
2150
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6126
// Load Unsigned Short/Char (16 bit UNsigned) into Long Register
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6127
instruct loadUS2L(rRegL dst, memory mem)
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6128
%{
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6129
  match(Set dst (ConvI2L (LoadUS mem)));
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6130
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6131
  ins_cost(125);
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6132
  format %{ "movzwq  $dst, $mem\t# ushort/char -> long" %}
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6133
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6134
  ins_encode %{
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6135
    __ movzwq($dst$$Register, $mem$$Address);
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6136
  %}
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6137
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6138
  ins_pipe(ialu_reg_mem);
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6139
%}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6140
3177
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6141
// Load Unsigned Short/Char (16 bit UNsigned) with mask 0xFF into Long Register
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6142
instruct loadUS2L_immI_255(rRegL dst, memory mem, immI_255 mask) %{
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6143
  match(Set dst (ConvI2L (AndI (LoadUS mem) mask)));
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6144
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6145
  format %{ "movzbq  $dst, $mem\t# ushort/char & 0xFF -> long" %}
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6146
  ins_encode %{
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6147
    __ movzbq($dst$$Register, $mem$$Address);
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6148
  %}
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6149
  ins_pipe(ialu_reg_mem);
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6150
%}
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6151
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6152
// Load Unsigned Short/Char (16 bit UNsigned) with mask into Long Register
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6153
instruct loadUS2L_immI16(rRegL dst, memory mem, immI16 mask, rFlagsReg cr) %{
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6154
  match(Set dst (ConvI2L (AndI (LoadUS mem) mask)));
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6155
  effect(KILL cr);
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6156
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6157
  format %{ "movzwq  $dst, $mem\t# ushort/char & 16-bit mask -> long\n\t"
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6158
            "andl    $dst, $mask" %}
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6159
  ins_encode %{
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6160
    Register Rdst = $dst$$Register;
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6161
    __ movzwq(Rdst, $mem$$Address);
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6162
    __ andl(Rdst, $mask$$constant);
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6163
  %}
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6164
  ins_pipe(ialu_reg_mem);
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6165
%}
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6166
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6167
// Load Integer
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6168
instruct loadI(rRegI dst, memory mem)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6169
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6170
  match(Set dst (LoadI mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6171
2150
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6172
  ins_cost(125);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6173
  format %{ "movl    $dst, $mem\t# int" %}
2150
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6174
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6175
  ins_encode %{
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6176
    __ movl($dst$$Register, $mem$$Address);
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6177
  %}
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6178
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6179
  ins_pipe(ialu_reg_mem);
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6180
%}
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6181
2872
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6182
// Load Integer (32 bit signed) to Byte (8 bit signed)
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6183
instruct loadI2B(rRegI dst, memory mem, immI_24 twentyfour) %{
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6184
  match(Set dst (RShiftI (LShiftI (LoadI mem) twentyfour) twentyfour));
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6185
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6186
  ins_cost(125);
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6187
  format %{ "movsbl  $dst, $mem\t# int -> byte" %}
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6188
  ins_encode %{
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6189
    __ movsbl($dst$$Register, $mem$$Address);
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6190
  %}
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6191
  ins_pipe(ialu_reg_mem);
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6192
%}
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6193
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6194
// Load Integer (32 bit signed) to Unsigned Byte (8 bit UNsigned)
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6195
instruct loadI2UB(rRegI dst, memory mem, immI_255 mask) %{
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6196
  match(Set dst (AndI (LoadI mem) mask));
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6197
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6198
  ins_cost(125);
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6199
  format %{ "movzbl  $dst, $mem\t# int -> ubyte" %}
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6200
  ins_encode %{
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6201
    __ movzbl($dst$$Register, $mem$$Address);
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6202
  %}
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6203
  ins_pipe(ialu_reg_mem);
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6204
%}
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6205
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6206
// Load Integer (32 bit signed) to Short (16 bit signed)
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6207
instruct loadI2S(rRegI dst, memory mem, immI_16 sixteen) %{
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6208
  match(Set dst (RShiftI (LShiftI (LoadI mem) sixteen) sixteen));
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6209
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6210
  ins_cost(125);
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6211
  format %{ "movswl  $dst, $mem\t# int -> short" %}
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6212
  ins_encode %{
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6213
    __ movswl($dst$$Register, $mem$$Address);
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6214
  %}
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6215
  ins_pipe(ialu_reg_mem);
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6216
%}
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6217
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6218
// Load Integer (32 bit signed) to Unsigned Short/Char (16 bit UNsigned)
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6219
instruct loadI2US(rRegI dst, memory mem, immI_65535 mask) %{
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6220
  match(Set dst (AndI (LoadI mem) mask));
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6221
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6222
  ins_cost(125);
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6223
  format %{ "movzwl  $dst, $mem\t# int -> ushort/char" %}
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6224
  ins_encode %{
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6225
    __ movzwl($dst$$Register, $mem$$Address);
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6226
  %}
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6227
  ins_pipe(ialu_reg_mem);
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6228
%}
93eb5ac6cfb0 6814842: Load shortening optimizations
twisti
parents: 2862
diff changeset
  6229
2150
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6230
// Load Integer into Long Register
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6231
instruct loadI2L(rRegL dst, memory mem)
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6232
%{
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6233
  match(Set dst (ConvI2L (LoadI mem)));
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6234
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6235
  ins_cost(125);
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6236
  format %{ "movslq  $dst, $mem\t# int -> long" %}
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6237
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6238
  ins_encode %{
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6239
    __ movslq($dst$$Register, $mem$$Address);
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6240
  %}
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6241
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6242
  ins_pipe(ialu_reg_mem);
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6243
%}
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6244
3177
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6245
// Load Integer with mask 0xFF into Long Register
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6246
instruct loadI2L_immI_255(rRegL dst, memory mem, immI_255 mask) %{
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6247
  match(Set dst (ConvI2L (AndI (LoadI mem) mask)));
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6248
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6249
  format %{ "movzbq  $dst, $mem\t# int & 0xFF -> long" %}
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6250
  ins_encode %{
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6251
    __ movzbq($dst$$Register, $mem$$Address);
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6252
  %}
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6253
  ins_pipe(ialu_reg_mem);
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6254
%}
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6255
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6256
// Load Integer with mask 0xFFFF into Long Register
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6257
instruct loadI2L_immI_65535(rRegL dst, memory mem, immI_65535 mask) %{
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6258
  match(Set dst (ConvI2L (AndI (LoadI mem) mask)));
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6259
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6260
  format %{ "movzwq  $dst, $mem\t# int & 0xFFFF -> long" %}
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6261
  ins_encode %{
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6262
    __ movzwq($dst$$Register, $mem$$Address);
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6263
  %}
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6264
  ins_pipe(ialu_reg_mem);
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6265
%}
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6266
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6267
// Load Integer with a 32-bit mask into Long Register
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6268
instruct loadI2L_immI(rRegL dst, memory mem, immI mask, rFlagsReg cr) %{
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6269
  match(Set dst (ConvI2L (AndI (LoadI mem) mask)));
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6270
  effect(KILL cr);
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6271
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6272
  format %{ "movl    $dst, $mem\t# int & 32-bit mask -> long\n\t"
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6273
            "andl    $dst, $mask" %}
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6274
  ins_encode %{
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6275
    Register Rdst = $dst$$Register;
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6276
    __ movl(Rdst, $mem$$Address);
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6277
    __ andl(Rdst, $mask$$constant);
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6278
  %}
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6279
  ins_pipe(ialu_reg_mem);
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6280
%}
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
  6281
2150
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6282
// Load Unsigned Integer into Long Register
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6283
instruct loadUI2L(rRegL dst, memory mem)
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6284
%{
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6285
  match(Set dst (LoadUI2L mem));
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6286
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6287
  ins_cost(125);
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6288
  format %{ "movl    $dst, $mem\t# uint -> long" %}
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6289
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6290
  ins_encode %{
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6291
    __ movl($dst$$Register, $mem$$Address);
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6292
  %}
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6293
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6294
  ins_pipe(ialu_reg_mem);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6295
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6296
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6297
// Load Long
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6298
instruct loadL(rRegL dst, memory mem)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6299
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6300
  match(Set dst (LoadL mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6301
2150
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6302
  ins_cost(125);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6303
  format %{ "movq    $dst, $mem\t# long" %}
2150
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6304
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6305
  ins_encode %{
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6306
    __ movq($dst$$Register, $mem$$Address);
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6307
  %}
0d91d17158cc 6797305: Add LoadUB and LoadUI opcode class
twisti
parents: 2148
diff changeset
  6308
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6309
  ins_pipe(ialu_reg_mem); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6310
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6311
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6312
// Load Range
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6313
instruct loadRange(rRegI dst, memory mem)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6314
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6315
  match(Set dst (LoadRange mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6316
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6317
  ins_cost(125); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6318
  format %{ "movl    $dst, $mem\t# range" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6319
  opcode(0x8B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6320
  ins_encode(REX_reg_mem(dst, mem), OpcP, reg_mem(dst, mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6321
  ins_pipe(ialu_reg_mem);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6322
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6323
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6324
// Load Pointer
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6325
instruct loadP(rRegP dst, memory mem)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6326
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6327
  match(Set dst (LoadP mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6328
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6329
  ins_cost(125); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6330
  format %{ "movq    $dst, $mem\t# ptr" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6331
  opcode(0x8B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6332
  ins_encode(REX_reg_mem_wide(dst, mem), OpcP, reg_mem(dst, mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6333
  ins_pipe(ialu_reg_mem); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6334
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6335
360
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  6336
// Load Compressed Pointer
589
a44a1e70a3e4 6695810: null oop passed to encode_heap_oop_not_null
kvn
parents: 392
diff changeset
  6337
instruct loadN(rRegN dst, memory mem)
360
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  6338
%{
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  6339
   match(Set dst (LoadN mem));
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  6340
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  6341
   ins_cost(125); // XXX
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  6342
   format %{ "movl    $dst, $mem\t# compressed ptr" %}
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  6343
   ins_encode %{
2254
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6344
     __ movl($dst$$Register, $mem$$Address);
360
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  6345
   %}
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  6346
   ins_pipe(ialu_reg_mem); // XXX
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  6347
%}
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  6348
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  6349
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6350
// Load Klass Pointer
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6351
instruct loadKlass(rRegP dst, memory mem)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6352
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6353
  match(Set dst (LoadKlass mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6354
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6355
  ins_cost(125); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6356
  format %{ "movq    $dst, $mem\t# class" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6357
  opcode(0x8B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6358
  ins_encode(REX_reg_mem_wide(dst, mem), OpcP, reg_mem(dst, mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6359
  ins_pipe(ialu_reg_mem); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6360
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6361
590
2954744d7bba 6703890: Compressed Oops: add LoadNKlass node to generate narrow oops (32-bits) compare instructions
kvn
parents: 589
diff changeset
  6362
// Load narrow Klass Pointer
2954744d7bba 6703890: Compressed Oops: add LoadNKlass node to generate narrow oops (32-bits) compare instructions
kvn
parents: 589
diff changeset
  6363
instruct loadNKlass(rRegN dst, memory mem)
2954744d7bba 6703890: Compressed Oops: add LoadNKlass node to generate narrow oops (32-bits) compare instructions
kvn
parents: 589
diff changeset
  6364
%{
2954744d7bba 6703890: Compressed Oops: add LoadNKlass node to generate narrow oops (32-bits) compare instructions
kvn
parents: 589
diff changeset
  6365
  match(Set dst (LoadNKlass mem));
360
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  6366
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  6367
  ins_cost(125); // XXX
608
fe8c5fbbc54e 6709093: Compressed Oops: reduce size of compiled methods
kvn
parents: 595
diff changeset
  6368
  format %{ "movl    $dst, $mem\t# compressed klass ptr" %}
360
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  6369
  ins_encode %{
2254
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6370
    __ movl($dst$$Register, $mem$$Address);
360
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  6371
  %}
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  6372
  ins_pipe(ialu_reg_mem); // XXX
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  6373
%}
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  6374
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6375
// Load Float
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6376
instruct loadF(regF dst, memory mem)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6377
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6378
  match(Set dst (LoadF mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6379
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6380
  ins_cost(145); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6381
  format %{ "movss   $dst, $mem\t# float" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6382
  opcode(0xF3, 0x0F, 0x10);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6383
  ins_encode(OpcP, REX_reg_mem(dst, mem), OpcS, OpcT, reg_mem(dst, mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6384
  ins_pipe(pipe_slow); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6385
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6386
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6387
// Load Double
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6388
instruct loadD_partial(regD dst, memory mem)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6389
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6390
  predicate(!UseXmmLoadAndClearUpper);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6391
  match(Set dst (LoadD mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6392
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6393
  ins_cost(145); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6394
  format %{ "movlpd  $dst, $mem\t# double" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6395
  opcode(0x66, 0x0F, 0x12);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6396
  ins_encode(OpcP, REX_reg_mem(dst, mem), OpcS, OpcT, reg_mem(dst, mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6397
  ins_pipe(pipe_slow); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6398
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6399
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6400
instruct loadD(regD dst, memory mem)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6401
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6402
  predicate(UseXmmLoadAndClearUpper);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6403
  match(Set dst (LoadD mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6404
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6405
  ins_cost(145); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6406
  format %{ "movsd   $dst, $mem\t# double" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6407
  opcode(0xF2, 0x0F, 0x10);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6408
  ins_encode(OpcP, REX_reg_mem(dst, mem), OpcS, OpcT, reg_mem(dst, mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6409
  ins_pipe(pipe_slow); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6410
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6411
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6412
// Load Aligned Packed Byte to XMM register
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6413
instruct loadA8B(regD dst, memory mem) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6414
  match(Set dst (Load8B mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6415
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6416
  format %{ "MOVQ  $dst,$mem\t! packed8B" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6417
  ins_encode( movq_ld(dst, mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6418
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6419
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6420
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6421
// Load Aligned Packed Short to XMM register
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6422
instruct loadA4S(regD dst, memory mem) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6423
  match(Set dst (Load4S mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6424
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6425
  format %{ "MOVQ  $dst,$mem\t! packed4S" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6426
  ins_encode( movq_ld(dst, mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6427
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6428
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6429
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6430
// Load Aligned Packed Char to XMM register
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6431
instruct loadA4C(regD dst, memory mem) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6432
  match(Set dst (Load4C mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6433
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6434
  format %{ "MOVQ  $dst,$mem\t! packed4C" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6435
  ins_encode( movq_ld(dst, mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6436
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6437
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6438
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6439
// Load Aligned Packed Integer to XMM register
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6440
instruct load2IU(regD dst, memory mem) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6441
  match(Set dst (Load2I mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6442
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6443
  format %{ "MOVQ  $dst,$mem\t! packed2I" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6444
  ins_encode( movq_ld(dst, mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6445
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6446
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6447
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6448
// Load Aligned Packed Single to XMM
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6449
instruct loadA2F(regD dst, memory mem) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6450
  match(Set dst (Load2F mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6451
  ins_cost(145);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6452
  format %{ "MOVQ  $dst,$mem\t! packed2F" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6453
  ins_encode( movq_ld(dst, mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6454
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6455
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6456
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6457
// Load Effective Address
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6458
instruct leaP8(rRegP dst, indOffset8 mem)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6459
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6460
  match(Set dst mem);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6461
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6462
  ins_cost(110); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6463
  format %{ "leaq    $dst, $mem\t# ptr 8" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6464
  opcode(0x8D);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6465
  ins_encode(REX_reg_mem_wide(dst, mem), OpcP, reg_mem(dst, mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6466
  ins_pipe(ialu_reg_reg_fat);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6467
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6468
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6469
instruct leaP32(rRegP dst, indOffset32 mem)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6470
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6471
  match(Set dst mem);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6472
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6473
  ins_cost(110);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6474
  format %{ "leaq    $dst, $mem\t# ptr 32" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6475
  opcode(0x8D);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6476
  ins_encode(REX_reg_mem_wide(dst, mem), OpcP, reg_mem(dst, mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6477
  ins_pipe(ialu_reg_reg_fat);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6478
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6479
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6480
// instruct leaPIdx(rRegP dst, indIndex mem)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6481
// %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6482
//   match(Set dst mem);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6483
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6484
//   ins_cost(110);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6485
//   format %{ "leaq    $dst, $mem\t# ptr idx" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6486
//   opcode(0x8D);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6487
//   ins_encode(REX_reg_mem_wide(dst, mem), OpcP, reg_mem(dst, mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6488
//   ins_pipe(ialu_reg_reg_fat);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6489
// %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6490
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6491
instruct leaPIdxOff(rRegP dst, indIndexOffset mem)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6492
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6493
  match(Set dst mem);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6494
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6495
  ins_cost(110);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6496
  format %{ "leaq    $dst, $mem\t# ptr idxoff" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6497
  opcode(0x8D);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6498
  ins_encode(REX_reg_mem_wide(dst, mem), OpcP, reg_mem(dst, mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6499
  ins_pipe(ialu_reg_reg_fat);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6500
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6501
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6502
instruct leaPIdxScale(rRegP dst, indIndexScale mem)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6503
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6504
  match(Set dst mem);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6505
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6506
  ins_cost(110);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6507
  format %{ "leaq    $dst, $mem\t# ptr idxscale" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6508
  opcode(0x8D);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6509
  ins_encode(REX_reg_mem_wide(dst, mem), OpcP, reg_mem(dst, mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6510
  ins_pipe(ialu_reg_reg_fat);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6511
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6512
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6513
instruct leaPIdxScaleOff(rRegP dst, indIndexScaleOffset mem)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6514
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6515
  match(Set dst mem);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6516
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6517
  ins_cost(110);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6518
  format %{ "leaq    $dst, $mem\t# ptr idxscaleoff" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6519
  opcode(0x8D);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6520
  ins_encode(REX_reg_mem_wide(dst, mem), OpcP, reg_mem(dst, mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6521
  ins_pipe(ialu_reg_reg_fat);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6522
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6523
2254
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6524
instruct leaPPosIdxScaleOff(rRegP dst, indPosIndexScaleOffset mem)
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6525
%{
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6526
  match(Set dst mem);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6527
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6528
  ins_cost(110);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6529
  format %{ "leaq    $dst, $mem\t# ptr posidxscaleoff" %}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6530
  opcode(0x8D);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6531
  ins_encode(REX_reg_mem_wide(dst, mem), OpcP, reg_mem(dst, mem));
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6532
  ins_pipe(ialu_reg_reg_fat);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6533
%}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6534
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6535
// Load Effective Address which uses Narrow (32-bits) oop
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6536
instruct leaPCompressedOopOffset(rRegP dst, indCompressedOopOffset mem)
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6537
%{
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6538
  predicate(UseCompressedOops && (Universe::narrow_oop_shift() != 0));
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6539
  match(Set dst mem);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6540
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6541
  ins_cost(110);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6542
  format %{ "leaq    $dst, $mem\t# ptr compressedoopoff32" %}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6543
  opcode(0x8D);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6544
  ins_encode(REX_reg_mem_wide(dst, mem), OpcP, reg_mem(dst, mem));
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6545
  ins_pipe(ialu_reg_reg_fat);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6546
%}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6547
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6548
instruct leaP8Narrow(rRegP dst, indOffset8Narrow mem)
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6549
%{
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6550
  predicate(Universe::narrow_oop_shift() == 0);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6551
  match(Set dst mem);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6552
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6553
  ins_cost(110); // XXX
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6554
  format %{ "leaq    $dst, $mem\t# ptr off8narrow" %}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6555
  opcode(0x8D);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6556
  ins_encode(REX_reg_mem_wide(dst, mem), OpcP, reg_mem(dst, mem));
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6557
  ins_pipe(ialu_reg_reg_fat);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6558
%}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6559
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6560
instruct leaP32Narrow(rRegP dst, indOffset32Narrow mem)
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6561
%{
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6562
  predicate(Universe::narrow_oop_shift() == 0);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6563
  match(Set dst mem);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6564
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6565
  ins_cost(110);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6566
  format %{ "leaq    $dst, $mem\t# ptr off32narrow" %}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6567
  opcode(0x8D);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6568
  ins_encode(REX_reg_mem_wide(dst, mem), OpcP, reg_mem(dst, mem));
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6569
  ins_pipe(ialu_reg_reg_fat);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6570
%}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6571
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6572
instruct leaPIdxOffNarrow(rRegP dst, indIndexOffsetNarrow mem)
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6573
%{
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6574
  predicate(Universe::narrow_oop_shift() == 0);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6575
  match(Set dst mem);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6576
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6577
  ins_cost(110);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6578
  format %{ "leaq    $dst, $mem\t# ptr idxoffnarrow" %}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6579
  opcode(0x8D);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6580
  ins_encode(REX_reg_mem_wide(dst, mem), OpcP, reg_mem(dst, mem));
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6581
  ins_pipe(ialu_reg_reg_fat);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6582
%}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6583
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6584
instruct leaPIdxScaleNarrow(rRegP dst, indIndexScaleNarrow mem)
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6585
%{
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6586
  predicate(Universe::narrow_oop_shift() == 0);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6587
  match(Set dst mem);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6588
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6589
  ins_cost(110);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6590
  format %{ "leaq    $dst, $mem\t# ptr idxscalenarrow" %}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6591
  opcode(0x8D);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6592
  ins_encode(REX_reg_mem_wide(dst, mem), OpcP, reg_mem(dst, mem));
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6593
  ins_pipe(ialu_reg_reg_fat);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6594
%}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6595
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6596
instruct leaPIdxScaleOffNarrow(rRegP dst, indIndexScaleOffsetNarrow mem)
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6597
%{
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6598
  predicate(Universe::narrow_oop_shift() == 0);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6599
  match(Set dst mem);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6600
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6601
  ins_cost(110);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6602
  format %{ "leaq    $dst, $mem\t# ptr idxscaleoffnarrow" %}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6603
  opcode(0x8D);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6604
  ins_encode(REX_reg_mem_wide(dst, mem), OpcP, reg_mem(dst, mem));
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6605
  ins_pipe(ialu_reg_reg_fat);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6606
%}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6607
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6608
instruct leaPPosIdxScaleOffNarrow(rRegP dst, indPosIndexScaleOffsetNarrow mem)
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6609
%{
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6610
  predicate(Universe::narrow_oop_shift() == 0);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6611
  match(Set dst mem);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6612
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6613
  ins_cost(110);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6614
  format %{ "leaq    $dst, $mem\t# ptr posidxscaleoffnarrow" %}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6615
  opcode(0x8D);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6616
  ins_encode(REX_reg_mem_wide(dst, mem), OpcP, reg_mem(dst, mem));
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6617
  ins_pipe(ialu_reg_reg_fat);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6618
%}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6619
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6620
instruct loadConI(rRegI dst, immI src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6621
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6622
  match(Set dst src);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6623
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6624
  format %{ "movl    $dst, $src\t# int" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6625
  ins_encode(load_immI(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6626
  ins_pipe(ialu_reg_fat); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6627
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6628
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6629
instruct loadConI0(rRegI dst, immI0 src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6630
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6631
  match(Set dst src);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6632
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6633
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6634
  ins_cost(50);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6635
  format %{ "xorl    $dst, $dst\t# int" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6636
  opcode(0x33); /* + rd */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6637
  ins_encode(REX_reg_reg(dst, dst), OpcP, reg_reg(dst, dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6638
  ins_pipe(ialu_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6639
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6640
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6641
instruct loadConL(rRegL dst, immL src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6642
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6643
  match(Set dst src);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6644
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6645
  ins_cost(150);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6646
  format %{ "movq    $dst, $src\t# long" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6647
  ins_encode(load_immL(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6648
  ins_pipe(ialu_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6649
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6650
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6651
instruct loadConL0(rRegL dst, immL0 src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6652
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6653
  match(Set dst src);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6654
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6655
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6656
  ins_cost(50);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6657
  format %{ "xorl    $dst, $dst\t# long" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6658
  opcode(0x33); /* + rd */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6659
  ins_encode(REX_reg_reg(dst, dst), OpcP, reg_reg(dst, dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6660
  ins_pipe(ialu_reg); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6661
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6662
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6663
instruct loadConUL32(rRegL dst, immUL32 src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6664
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6665
  match(Set dst src);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6666
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6667
  ins_cost(60);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6668
  format %{ "movl    $dst, $src\t# long (unsigned 32-bit)" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6669
  ins_encode(load_immUL32(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6670
  ins_pipe(ialu_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6671
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6672
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6673
instruct loadConL32(rRegL dst, immL32 src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6674
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6675
  match(Set dst src);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6676
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6677
  ins_cost(70);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6678
  format %{ "movq    $dst, $src\t# long (32-bit)" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6679
  ins_encode(load_immL32(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6680
  ins_pipe(ialu_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6681
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6682
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6683
instruct loadConP(rRegP dst, immP src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6684
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6685
  match(Set dst src);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6686
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6687
  format %{ "movq    $dst, $src\t# ptr" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6688
  ins_encode(load_immP(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6689
  ins_pipe(ialu_reg_fat); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6690
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6691
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6692
instruct loadConP0(rRegP dst, immP0 src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6693
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6694
  match(Set dst src);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6695
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6696
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6697
  ins_cost(50);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6698
  format %{ "xorl    $dst, $dst\t# ptr" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6699
  opcode(0x33); /* + rd */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6700
  ins_encode(REX_reg_reg(dst, dst), OpcP, reg_reg(dst, dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6701
  ins_pipe(ialu_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6702
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6703
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6704
instruct loadConP31(rRegP dst, immP31 src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6705
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6706
  match(Set dst src);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6707
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6708
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6709
  ins_cost(60);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6710
  format %{ "movl    $dst, $src\t# ptr (positive 32-bit)" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6711
  ins_encode(load_immP31(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6712
  ins_pipe(ialu_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6713
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6714
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6715
instruct loadConF(regF dst, immF src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6716
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6717
  match(Set dst src);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6718
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6719
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6720
  format %{ "movss   $dst, [$src]" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6721
  ins_encode(load_conF(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6722
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6723
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6724
360
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  6725
instruct loadConN0(rRegN dst, immN0 src, rFlagsReg cr) %{
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  6726
  match(Set dst src);
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  6727
  effect(KILL cr);
371
1aacedc9db7c 6689060: Escape Analysis does not work with Compressed Oops
kvn
parents: 360
diff changeset
  6728
  format %{ "xorq    $dst, $src\t# compressed NULL ptr" %}
360
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  6729
  ins_encode %{
2254
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6730
    __ xorq($dst$$Register, $dst$$Register);
360
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  6731
  %}
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  6732
  ins_pipe(ialu_reg);
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  6733
%}
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  6734
590
2954744d7bba 6703890: Compressed Oops: add LoadNKlass node to generate narrow oops (32-bits) compare instructions
kvn
parents: 589
diff changeset
  6735
instruct loadConN(rRegN dst, immN src) %{
360
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  6736
  match(Set dst src);
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  6737
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  6738
  ins_cost(125);
590
2954744d7bba 6703890: Compressed Oops: add LoadNKlass node to generate narrow oops (32-bits) compare instructions
kvn
parents: 589
diff changeset
  6739
  format %{ "movl    $dst, $src\t# compressed ptr" %}
360
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  6740
  ins_encode %{
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  6741
    address con = (address)$src$$constant;
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  6742
    if (con == NULL) {
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  6743
      ShouldNotReachHere();
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  6744
    } else {
2254
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6745
      __ set_narrow_oop($dst$$Register, (jobject)$src$$constant);
360
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  6746
    }
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  6747
  %}
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  6748
  ins_pipe(ialu_reg_fat); // XXX
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  6749
%}
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  6750
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6751
instruct loadConF0(regF dst, immF0 src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6752
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6753
  match(Set dst src);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6754
  ins_cost(100);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6755
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6756
  format %{ "xorps   $dst, $dst\t# float 0.0" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6757
  opcode(0x0F, 0x57);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6758
  ins_encode(REX_reg_reg(dst, dst), OpcP, OpcS, reg_reg(dst, dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6759
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6760
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6761
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6762
// Use the same format since predicate() can not be used here.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6763
instruct loadConD(regD dst, immD src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6764
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6765
  match(Set dst src);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6766
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6767
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6768
  format %{ "movsd   $dst, [$src]" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6769
  ins_encode(load_conD(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6770
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6771
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6772
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6773
instruct loadConD0(regD dst, immD0 src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6774
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6775
  match(Set dst src);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6776
  ins_cost(100);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6777
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6778
  format %{ "xorpd   $dst, $dst\t# double 0.0" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6779
  opcode(0x66, 0x0F, 0x57);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6780
  ins_encode(OpcP, REX_reg_reg(dst, dst), OpcS, OpcT, reg_reg(dst, dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6781
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6782
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6783
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6784
instruct loadSSI(rRegI dst, stackSlotI src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6785
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6786
  match(Set dst src);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6787
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6788
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6789
  format %{ "movl    $dst, $src\t# int stk" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6790
  opcode(0x8B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6791
  ins_encode(REX_reg_mem(dst, src), OpcP, reg_mem(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6792
  ins_pipe(ialu_reg_mem);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6793
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6794
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6795
instruct loadSSL(rRegL dst, stackSlotL src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6796
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6797
  match(Set dst src);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6798
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6799
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6800
  format %{ "movq    $dst, $src\t# long stk" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6801
  opcode(0x8B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6802
  ins_encode(REX_reg_mem_wide(dst, src), OpcP, reg_mem(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6803
  ins_pipe(ialu_reg_mem);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6804
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6805
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6806
instruct loadSSP(rRegP dst, stackSlotP src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6807
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6808
  match(Set dst src);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6809
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6810
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6811
  format %{ "movq    $dst, $src\t# ptr stk" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6812
  opcode(0x8B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6813
  ins_encode(REX_reg_mem_wide(dst, src), OpcP, reg_mem(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6814
  ins_pipe(ialu_reg_mem);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6815
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6816
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6817
instruct loadSSF(regF dst, stackSlotF src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6818
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6819
  match(Set dst src);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6820
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6821
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6822
  format %{ "movss   $dst, $src\t# float stk" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6823
  opcode(0xF3, 0x0F, 0x10);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6824
  ins_encode(OpcP, REX_reg_mem(dst, src), OpcS, OpcT, reg_mem(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6825
  ins_pipe(pipe_slow); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6826
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6827
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6828
// Use the same format since predicate() can not be used here.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6829
instruct loadSSD(regD dst, stackSlotD src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6830
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6831
  match(Set dst src);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6832
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6833
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6834
  format %{ "movsd   $dst, $src\t# double stk" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6835
  ins_encode  %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6836
    __ movdbl($dst$$XMMRegister, Address(rsp, $src$$disp));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6837
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6838
  ins_pipe(pipe_slow); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6839
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6840
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6841
// Prefetch instructions.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6842
// Must be safe to execute with invalid address (cannot fault).
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6843
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6844
instruct prefetchr( memory mem ) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6845
  predicate(ReadPrefetchInstr==3);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6846
  match(PrefetchRead mem);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6847
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6848
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6849
  format %{ "PREFETCHR $mem\t# Prefetch into level 1 cache" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6850
  opcode(0x0F, 0x0D);     /* Opcode 0F 0D /0 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6851
  ins_encode(REX_mem(mem), OpcP, OpcS, RM_opc_mem(0x00, mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6852
  ins_pipe(ialu_mem);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6853
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6854
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6855
instruct prefetchrNTA( memory mem ) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6856
  predicate(ReadPrefetchInstr==0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6857
  match(PrefetchRead mem);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6858
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6859
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6860
  format %{ "PREFETCHNTA $mem\t# Prefetch into non-temporal cache for read" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6861
  opcode(0x0F, 0x18);     /* Opcode 0F 18 /0 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6862
  ins_encode(REX_mem(mem), OpcP, OpcS, RM_opc_mem(0x00, mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6863
  ins_pipe(ialu_mem);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6864
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6865
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6866
instruct prefetchrT0( memory mem ) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6867
  predicate(ReadPrefetchInstr==1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6868
  match(PrefetchRead mem);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6869
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6870
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6871
  format %{ "PREFETCHT0 $mem\t# prefetch into L1 and L2 caches for read" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6872
  opcode(0x0F, 0x18); /* Opcode 0F 18 /1 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6873
  ins_encode(REX_mem(mem), OpcP, OpcS, RM_opc_mem(0x01, mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6874
  ins_pipe(ialu_mem);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6875
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6876
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6877
instruct prefetchrT2( memory mem ) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6878
  predicate(ReadPrefetchInstr==2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6879
  match(PrefetchRead mem);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6880
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6881
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6882
  format %{ "PREFETCHT2 $mem\t# prefetch into L2 caches for read" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6883
  opcode(0x0F, 0x18); /* Opcode 0F 18 /3 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6884
  ins_encode(REX_mem(mem), OpcP, OpcS, RM_opc_mem(0x03, mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6885
  ins_pipe(ialu_mem);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6886
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6887
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6888
instruct prefetchw( memory mem ) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6889
  predicate(AllocatePrefetchInstr==3);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6890
  match(PrefetchWrite mem);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6891
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6892
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6893
  format %{ "PREFETCHW $mem\t# Prefetch into level 1 cache and mark modified" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6894
  opcode(0x0F, 0x0D);     /* Opcode 0F 0D /1 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6895
  ins_encode(REX_mem(mem), OpcP, OpcS, RM_opc_mem(0x01, mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6896
  ins_pipe(ialu_mem);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6897
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6898
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6899
instruct prefetchwNTA( memory mem ) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6900
  predicate(AllocatePrefetchInstr==0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6901
  match(PrefetchWrite mem);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6902
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6903
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6904
  format %{ "PREFETCHNTA $mem\t# Prefetch to non-temporal cache for write" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6905
  opcode(0x0F, 0x18);     /* Opcode 0F 18 /0 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6906
  ins_encode(REX_mem(mem), OpcP, OpcS, RM_opc_mem(0x00, mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6907
  ins_pipe(ialu_mem);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6908
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6909
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6910
instruct prefetchwT0( memory mem ) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6911
  predicate(AllocatePrefetchInstr==1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6912
  match(PrefetchWrite mem);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6913
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6914
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6915
  format %{ "PREFETCHT0 $mem\t# Prefetch to level 1 and 2 caches for write" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6916
  opcode(0x0F, 0x18);     /* Opcode 0F 18 /1 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6917
  ins_encode(REX_mem(mem), OpcP, OpcS, RM_opc_mem(0x01, mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6918
  ins_pipe(ialu_mem);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6919
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6920
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6921
instruct prefetchwT2( memory mem ) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6922
  predicate(AllocatePrefetchInstr==2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6923
  match(PrefetchWrite mem);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6924
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6925
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6926
  format %{ "PREFETCHT2 $mem\t# Prefetch to level 2 cache for write" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6927
  opcode(0x0F, 0x18);     /* Opcode 0F 18 /3 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6928
  ins_encode(REX_mem(mem), OpcP, OpcS, RM_opc_mem(0x03, mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6929
  ins_pipe(ialu_mem);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6930
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6931
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6932
//----------Store Instructions-------------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6933
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6934
// Store Byte
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6935
instruct storeB(memory mem, rRegI src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6936
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6937
  match(Set mem (StoreB mem src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6938
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6939
  ins_cost(125); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6940
  format %{ "movb    $mem, $src\t# byte" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6941
  opcode(0x88);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6942
  ins_encode(REX_breg_mem(src, mem), OpcP, reg_mem(src, mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6943
  ins_pipe(ialu_mem_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6944
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6945
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6946
// Store Char/Short
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6947
instruct storeC(memory mem, rRegI src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6948
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6949
  match(Set mem (StoreC mem src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6950
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6951
  ins_cost(125); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6952
  format %{ "movw    $mem, $src\t# char/short" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6953
  opcode(0x89);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6954
  ins_encode(SizePrefix, REX_reg_mem(src, mem), OpcP, reg_mem(src, mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6955
  ins_pipe(ialu_mem_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6956
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6957
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6958
// Store Integer
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6959
instruct storeI(memory mem, rRegI src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6960
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6961
  match(Set mem (StoreI mem src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6962
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6963
  ins_cost(125); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6964
  format %{ "movl    $mem, $src\t# int" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6965
  opcode(0x89);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6966
  ins_encode(REX_reg_mem(src, mem), OpcP, reg_mem(src, mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6967
  ins_pipe(ialu_mem_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6968
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6969
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6970
// Store Long
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6971
instruct storeL(memory mem, rRegL src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6972
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6973
  match(Set mem (StoreL mem src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6974
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6975
  ins_cost(125); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6976
  format %{ "movq    $mem, $src\t# long" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6977
  opcode(0x89);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6978
  ins_encode(REX_reg_mem_wide(src, mem), OpcP, reg_mem(src, mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6979
  ins_pipe(ialu_mem_reg); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6980
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6981
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6982
// Store Pointer
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6983
instruct storeP(memory mem, any_RegP src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6984
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6985
  match(Set mem (StoreP mem src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6986
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6987
  ins_cost(125); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6988
  format %{ "movq    $mem, $src\t# ptr" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6989
  opcode(0x89);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6990
  ins_encode(REX_reg_mem_wide(src, mem), OpcP, reg_mem(src, mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6991
  ins_pipe(ialu_mem_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6992
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  6993
2254
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6994
instruct storeImmP0(memory mem, immP0 zero)
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6995
%{
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6996
  predicate(UseCompressedOops && (Universe::narrow_oop_base() == NULL));
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6997
  match(Set mem (StoreP mem zero));
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6998
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  6999
  ins_cost(125); // XXX
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7000
  format %{ "movq    $mem, R12\t# ptr (R12_heapbase==0)" %}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7001
  ins_encode %{
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7002
    __ movq($mem$$Address, r12);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7003
  %}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7004
  ins_pipe(ialu_mem_reg);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7005
%}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7006
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7007
// Store NULL Pointer, mark word, or other simple pointer constant.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7008
instruct storeImmP(memory mem, immP31 src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7009
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7010
  match(Set mem (StoreP mem src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7011
2254
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7012
  ins_cost(150); // XXX
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7013
  format %{ "movq    $mem, $src\t# ptr" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7014
  opcode(0xC7); /* C7 /0 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7015
  ins_encode(REX_mem_wide(mem), OpcP, RM_opc_mem(0x00, mem), Con32(src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7016
  ins_pipe(ialu_mem_imm);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7017
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7018
360
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  7019
// Store Compressed Pointer
589
a44a1e70a3e4 6695810: null oop passed to encode_heap_oop_not_null
kvn
parents: 392
diff changeset
  7020
instruct storeN(memory mem, rRegN src)
360
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  7021
%{
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  7022
  match(Set mem (StoreN mem src));
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  7023
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  7024
  ins_cost(125); // XXX
590
2954744d7bba 6703890: Compressed Oops: add LoadNKlass node to generate narrow oops (32-bits) compare instructions
kvn
parents: 589
diff changeset
  7025
  format %{ "movl    $mem, $src\t# compressed ptr" %}
360
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  7026
  ins_encode %{
2254
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7027
    __ movl($mem$$Address, $src$$Register);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7028
  %}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7029
  ins_pipe(ialu_mem_reg);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7030
%}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7031
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7032
instruct storeImmN0(memory mem, immN0 zero)
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7033
%{
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7034
  predicate(Universe::narrow_oop_base() == NULL);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7035
  match(Set mem (StoreN mem zero));
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7036
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7037
  ins_cost(125); // XXX
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7038
  format %{ "movl    $mem, R12\t# compressed ptr (R12_heapbase==0)" %}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7039
  ins_encode %{
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7040
    __ movl($mem$$Address, r12);
360
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  7041
  %}
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  7042
  ins_pipe(ialu_mem_reg);
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  7043
%}
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  7044
2254
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7045
instruct storeImmN(memory mem, immN src)
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7046
%{
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7047
  match(Set mem (StoreN mem src));
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7048
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7049
  ins_cost(150); // XXX
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7050
  format %{ "movl    $mem, $src\t# compressed ptr" %}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7051
  ins_encode %{
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7052
    address con = (address)$src$$constant;
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7053
    if (con == NULL) {
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7054
      __ movl($mem$$Address, (int32_t)0);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7055
    } else {
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7056
      __ set_narrow_oop($mem$$Address, (jobject)$src$$constant);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7057
    }
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7058
  %}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7059
  ins_pipe(ialu_mem_imm);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7060
%}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7061
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7062
// Store Integer Immediate
2254
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7063
instruct storeImmI0(memory mem, immI0 zero)
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7064
%{
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7065
  predicate(UseCompressedOops && (Universe::narrow_oop_base() == NULL));
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7066
  match(Set mem (StoreI mem zero));
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7067
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7068
  ins_cost(125); // XXX
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7069
  format %{ "movl    $mem, R12\t# int (R12_heapbase==0)" %}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7070
  ins_encode %{
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7071
    __ movl($mem$$Address, r12);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7072
  %}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7073
  ins_pipe(ialu_mem_reg);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7074
%}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7075
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7076
instruct storeImmI(memory mem, immI src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7077
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7078
  match(Set mem (StoreI mem src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7079
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7080
  ins_cost(150);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7081
  format %{ "movl    $mem, $src\t# int" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7082
  opcode(0xC7); /* C7 /0 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7083
  ins_encode(REX_mem(mem), OpcP, RM_opc_mem(0x00, mem), Con32(src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7084
  ins_pipe(ialu_mem_imm);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7085
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7086
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7087
// Store Long Immediate
2254
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7088
instruct storeImmL0(memory mem, immL0 zero)
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7089
%{
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7090
  predicate(UseCompressedOops && (Universe::narrow_oop_base() == NULL));
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7091
  match(Set mem (StoreL mem zero));
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7092
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7093
  ins_cost(125); // XXX
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7094
  format %{ "movq    $mem, R12\t# long (R12_heapbase==0)" %}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7095
  ins_encode %{
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7096
    __ movq($mem$$Address, r12);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7097
  %}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7098
  ins_pipe(ialu_mem_reg);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7099
%}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7100
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7101
instruct storeImmL(memory mem, immL32 src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7102
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7103
  match(Set mem (StoreL mem src));
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 %{ "movq    $mem, $src\t# long" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7107
  opcode(0xC7); /* C7 /0 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7108
  ins_encode(REX_mem_wide(mem), OpcP, RM_opc_mem(0x00, mem), Con32(src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7109
  ins_pipe(ialu_mem_imm);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7110
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7111
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7112
// Store Short/Char Immediate
2254
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7113
instruct storeImmC0(memory mem, immI0 zero)
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7114
%{
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7115
  predicate(UseCompressedOops && (Universe::narrow_oop_base() == NULL));
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7116
  match(Set mem (StoreC mem zero));
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7117
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7118
  ins_cost(125); // XXX
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7119
  format %{ "movw    $mem, R12\t# short/char (R12_heapbase==0)" %}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7120
  ins_encode %{
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7121
    __ movw($mem$$Address, r12);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7122
  %}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7123
  ins_pipe(ialu_mem_reg);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7124
%}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7125
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7126
instruct storeImmI16(memory mem, immI16 src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7127
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7128
  predicate(UseStoreImmI16);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7129
  match(Set mem (StoreC mem src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7130
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7131
  ins_cost(150);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7132
  format %{ "movw    $mem, $src\t# short/char" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7133
  opcode(0xC7); /* C7 /0 Same as 32 store immediate with prefix */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7134
  ins_encode(SizePrefix, REX_mem(mem), OpcP, RM_opc_mem(0x00, mem),Con16(src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7135
  ins_pipe(ialu_mem_imm);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7136
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7137
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7138
// Store Byte Immediate
2254
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7139
instruct storeImmB0(memory mem, immI0 zero)
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7140
%{
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7141
  predicate(UseCompressedOops && (Universe::narrow_oop_base() == NULL));
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7142
  match(Set mem (StoreB mem zero));
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7143
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7144
  ins_cost(125); // XXX
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7145
  format %{ "movb    $mem, R12\t# short/char (R12_heapbase==0)" %}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7146
  ins_encode %{
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7147
    __ movb($mem$$Address, r12);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7148
  %}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7149
  ins_pipe(ialu_mem_reg);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7150
%}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7151
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7152
instruct storeImmB(memory mem, immI8 src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7153
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7154
  match(Set mem (StoreB mem src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7155
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7156
  ins_cost(150); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7157
  format %{ "movb    $mem, $src\t# byte" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7158
  opcode(0xC6); /* C6 /0 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7159
  ins_encode(REX_mem(mem), OpcP, RM_opc_mem(0x00, mem), Con8or32(src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7160
  ins_pipe(ialu_mem_imm);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7161
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7162
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7163
// Store Aligned Packed Byte XMM register to memory
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7164
instruct storeA8B(memory mem, regD src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7165
  match(Set mem (Store8B mem src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7166
  ins_cost(145);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7167
  format %{ "MOVQ  $mem,$src\t! packed8B" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7168
  ins_encode( movq_st(mem, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7169
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7170
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7171
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7172
// Store Aligned Packed Char/Short XMM register to memory
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7173
instruct storeA4C(memory mem, regD src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7174
  match(Set mem (Store4C mem src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7175
  ins_cost(145);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7176
  format %{ "MOVQ  $mem,$src\t! packed4C" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7177
  ins_encode( movq_st(mem, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7178
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7179
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7180
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7181
// Store Aligned Packed Integer XMM register to memory
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7182
instruct storeA2I(memory mem, regD src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7183
  match(Set mem (Store2I mem src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7184
  ins_cost(145);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7185
  format %{ "MOVQ  $mem,$src\t! packed2I" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7186
  ins_encode( movq_st(mem, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7187
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7188
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7189
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7190
// Store CMS card-mark Immediate
2254
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7191
instruct storeImmCM0_reg(memory mem, immI0 zero)
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7192
%{
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7193
  predicate(UseCompressedOops && (Universe::narrow_oop_base() == NULL));
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7194
  match(Set mem (StoreCM mem zero));
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7195
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7196
  ins_cost(125); // XXX
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7197
  format %{ "movb    $mem, R12\t# CMS card-mark byte 0 (R12_heapbase==0)" %}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7198
  ins_encode %{
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7199
    __ movb($mem$$Address, r12);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7200
  %}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7201
  ins_pipe(ialu_mem_reg);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7202
%}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7203
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7204
instruct storeImmCM0(memory mem, immI0 src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7205
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7206
  match(Set mem (StoreCM mem src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7207
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7208
  ins_cost(150); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7209
  format %{ "movb    $mem, $src\t# CMS card-mark byte 0" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7210
  opcode(0xC6); /* C6 /0 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7211
  ins_encode(REX_mem(mem), OpcP, RM_opc_mem(0x00, mem), Con8or32(src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7212
  ins_pipe(ialu_mem_imm);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7213
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7214
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7215
// Store Aligned Packed Single Float XMM register to memory
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7216
instruct storeA2F(memory mem, regD src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7217
  match(Set mem (Store2F mem src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7218
  ins_cost(145);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7219
  format %{ "MOVQ  $mem,$src\t! packed2F" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7220
  ins_encode( movq_st(mem, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7221
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7222
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7223
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7224
// Store Float
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7225
instruct storeF(memory mem, regF src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7226
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7227
  match(Set mem (StoreF mem src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7228
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7229
  ins_cost(95); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7230
  format %{ "movss   $mem, $src\t# float" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7231
  opcode(0xF3, 0x0F, 0x11);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7232
  ins_encode(OpcP, REX_reg_mem(src, mem), OpcS, OpcT, reg_mem(src, mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7233
  ins_pipe(pipe_slow); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7234
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7235
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7236
// Store immediate Float value (it is faster than store from XMM register)
2254
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7237
instruct storeF0(memory mem, immF0 zero)
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7238
%{
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7239
  predicate(UseCompressedOops && (Universe::narrow_oop_base() == NULL));
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7240
  match(Set mem (StoreF mem zero));
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7241
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7242
  ins_cost(25); // XXX
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7243
  format %{ "movl    $mem, R12\t# float 0. (R12_heapbase==0)" %}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7244
  ins_encode %{
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7245
    __ movl($mem$$Address, r12);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7246
  %}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7247
  ins_pipe(ialu_mem_reg);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7248
%}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7249
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7250
instruct storeF_imm(memory mem, immF src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7251
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7252
  match(Set mem (StoreF mem src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7253
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7254
  ins_cost(50);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7255
  format %{ "movl    $mem, $src\t# float" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7256
  opcode(0xC7); /* C7 /0 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7257
  ins_encode(REX_mem(mem), OpcP, RM_opc_mem(0x00, mem), Con32F_as_bits(src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7258
  ins_pipe(ialu_mem_imm);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7259
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7260
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7261
// Store Double
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7262
instruct storeD(memory mem, regD src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7263
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7264
  match(Set mem (StoreD mem src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7265
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7266
  ins_cost(95); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7267
  format %{ "movsd   $mem, $src\t# double" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7268
  opcode(0xF2, 0x0F, 0x11);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7269
  ins_encode(OpcP, REX_reg_mem(src, mem), OpcS, OpcT, reg_mem(src, mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7270
  ins_pipe(pipe_slow); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7271
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7272
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7273
// Store immediate double 0.0 (it is faster than store from XMM register)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7274
instruct storeD0_imm(memory mem, immD0 src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7275
%{
2254
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7276
  predicate(!UseCompressedOops || (Universe::narrow_oop_base() != NULL));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7277
  match(Set mem (StoreD mem src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7278
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7279
  ins_cost(50);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7280
  format %{ "movq    $mem, $src\t# double 0." %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7281
  opcode(0xC7); /* C7 /0 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7282
  ins_encode(REX_mem_wide(mem), OpcP, RM_opc_mem(0x00, mem), Con32F_as_bits(src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7283
  ins_pipe(ialu_mem_imm);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7284
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7285
2254
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7286
instruct storeD0(memory mem, immD0 zero)
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7287
%{
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7288
  predicate(UseCompressedOops && (Universe::narrow_oop_base() == NULL));
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7289
  match(Set mem (StoreD mem zero));
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7290
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7291
  ins_cost(25); // XXX
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7292
  format %{ "movq    $mem, R12\t# double 0. (R12_heapbase==0)" %}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7293
  ins_encode %{
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7294
    __ movq($mem$$Address, r12);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7295
  %}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7296
  ins_pipe(ialu_mem_reg);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7297
%}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7298
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7299
instruct storeSSI(stackSlotI dst, rRegI src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7300
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7301
  match(Set dst src);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7302
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7303
  ins_cost(100);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7304
  format %{ "movl    $dst, $src\t# int stk" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7305
  opcode(0x89);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7306
  ins_encode(REX_reg_mem(src, dst), OpcP, reg_mem(src, dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7307
  ins_pipe( ialu_mem_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7308
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7309
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7310
instruct storeSSL(stackSlotL dst, rRegL src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7311
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7312
  match(Set dst src);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7313
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7314
  ins_cost(100);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7315
  format %{ "movq    $dst, $src\t# long stk" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7316
  opcode(0x89);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7317
  ins_encode(REX_reg_mem_wide(src, dst), OpcP, reg_mem(src, dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7318
  ins_pipe(ialu_mem_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7319
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7320
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7321
instruct storeSSP(stackSlotP dst, rRegP src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7322
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7323
  match(Set dst src);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7324
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7325
  ins_cost(100);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7326
  format %{ "movq    $dst, $src\t# ptr stk" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7327
  opcode(0x89);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7328
  ins_encode(REX_reg_mem_wide(src, dst), OpcP, reg_mem(src, dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7329
  ins_pipe(ialu_mem_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7330
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7331
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7332
instruct storeSSF(stackSlotF dst, regF src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7333
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7334
  match(Set dst src);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7335
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7336
  ins_cost(95); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7337
  format %{ "movss   $dst, $src\t# float stk" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7338
  opcode(0xF3, 0x0F, 0x11);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7339
  ins_encode(OpcP, REX_reg_mem(src, dst), OpcS, OpcT, reg_mem(src, dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7340
  ins_pipe(pipe_slow); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7341
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7342
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7343
instruct storeSSD(stackSlotD dst, regD src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7344
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7345
  match(Set dst src);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7346
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7347
  ins_cost(95); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7348
  format %{ "movsd   $dst, $src\t# double stk" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7349
  opcode(0xF2, 0x0F, 0x11);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7350
  ins_encode(OpcP, REX_reg_mem(src, dst), OpcS, OpcT, reg_mem(src, dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7351
  ins_pipe(pipe_slow); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7352
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7353
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7354
//----------BSWAP Instructions-------------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7355
instruct bytes_reverse_int(rRegI dst) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7356
  match(Set dst (ReverseBytesI dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7357
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7358
  format %{ "bswapl  $dst" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7359
  opcode(0x0F, 0xC8);  /*Opcode 0F /C8 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7360
  ins_encode( REX_reg(dst), OpcP, opc2_reg(dst) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7361
  ins_pipe( ialu_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7362
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7363
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7364
instruct bytes_reverse_long(rRegL dst) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7365
  match(Set dst (ReverseBytesL dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7366
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7367
  format %{ "bswapq  $dst" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7368
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7369
  opcode(0x0F, 0xC8); /* Opcode 0F /C8 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7370
  ins_encode( REX_reg_wide(dst), OpcP, opc2_reg(dst) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7371
  ins_pipe( ialu_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7372
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7373
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7374
instruct loadI_reversed(rRegI dst, memory src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7375
  match(Set dst (ReverseBytesI (LoadI src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7376
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7377
  format %{ "bswap_movl $dst, $src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7378
  opcode(0x8B, 0x0F, 0xC8); /* Opcode 8B 0F C8 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7379
  ins_encode(REX_reg_mem(dst, src), OpcP, reg_mem(dst, src), REX_reg(dst), OpcS, opc3_reg(dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7380
  ins_pipe( ialu_reg_mem );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7381
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7382
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7383
instruct loadL_reversed(rRegL dst, memory src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7384
  match(Set dst (ReverseBytesL (LoadL src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7385
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7386
  format %{ "bswap_movq $dst, $src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7387
  opcode(0x8B, 0x0F, 0xC8); /* Opcode 8B 0F C8 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7388
  ins_encode(REX_reg_mem_wide(dst, src), OpcP, reg_mem(dst, src), REX_reg_wide(dst), OpcS, opc3_reg(dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7389
  ins_pipe( ialu_reg_mem );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7390
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7391
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7392
instruct storeI_reversed(memory dst, rRegI src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7393
  match(Set dst (StoreI dst (ReverseBytesI  src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7394
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7395
  format %{ "movl_bswap $dst, $src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7396
  opcode(0x0F, 0xC8, 0x89); /* Opcode 0F C8 89 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7397
  ins_encode( REX_reg(src), OpcP, opc2_reg(src), REX_reg_mem(src, dst), OpcT, reg_mem(src, dst) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7398
  ins_pipe( ialu_mem_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7399
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7400
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7401
instruct storeL_reversed(memory dst, rRegL src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7402
  match(Set dst (StoreL dst (ReverseBytesL  src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7403
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7404
  format %{ "movq_bswap $dst, $src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7405
  opcode(0x0F, 0xC8, 0x89); /* Opcode 0F C8 89 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7406
  ins_encode( REX_reg_wide(src), OpcP, opc2_reg(src), REX_reg_mem_wide(src, dst), OpcT, reg_mem(src, dst) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7407
  ins_pipe( ialu_mem_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7408
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7409
2255
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2254
diff changeset
  7410
2862
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7411
//---------- Zeros Count Instructions ------------------------------------------
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7412
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7413
instruct countLeadingZerosI(rRegI dst, rRegI src, rFlagsReg cr) %{
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7414
  predicate(UseCountLeadingZerosInstruction);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7415
  match(Set dst (CountLeadingZerosI src));
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7416
  effect(KILL cr);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7417
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7418
  format %{ "lzcntl  $dst, $src\t# count leading zeros (int)" %}
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7419
  ins_encode %{
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7420
    __ lzcntl($dst$$Register, $src$$Register);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7421
  %}
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7422
  ins_pipe(ialu_reg);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7423
%}
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7424
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7425
instruct countLeadingZerosI_bsr(rRegI dst, rRegI src, rFlagsReg cr) %{
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7426
  predicate(!UseCountLeadingZerosInstruction);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7427
  match(Set dst (CountLeadingZerosI src));
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7428
  effect(KILL cr);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7429
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7430
  format %{ "bsrl    $dst, $src\t# count leading zeros (int)\n\t"
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7431
            "jnz     skip\n\t"
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7432
            "movl    $dst, -1\n"
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7433
      "skip:\n\t"
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7434
            "negl    $dst\n\t"
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7435
            "addl    $dst, 31" %}
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7436
  ins_encode %{
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7437
    Register Rdst = $dst$$Register;
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7438
    Register Rsrc = $src$$Register;
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7439
    Label skip;
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7440
    __ bsrl(Rdst, Rsrc);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7441
    __ jccb(Assembler::notZero, skip);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7442
    __ movl(Rdst, -1);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7443
    __ bind(skip);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7444
    __ negl(Rdst);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7445
    __ addl(Rdst, BitsPerInt - 1);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7446
  %}
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7447
  ins_pipe(ialu_reg);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7448
%}
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7449
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7450
instruct countLeadingZerosL(rRegI dst, rRegL src, rFlagsReg cr) %{
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7451
  predicate(UseCountLeadingZerosInstruction);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7452
  match(Set dst (CountLeadingZerosL src));
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7453
  effect(KILL cr);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7454
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7455
  format %{ "lzcntq  $dst, $src\t# count leading zeros (long)" %}
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7456
  ins_encode %{
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7457
    __ lzcntq($dst$$Register, $src$$Register);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7458
  %}
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7459
  ins_pipe(ialu_reg);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7460
%}
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7461
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7462
instruct countLeadingZerosL_bsr(rRegI dst, rRegL src, rFlagsReg cr) %{
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7463
  predicate(!UseCountLeadingZerosInstruction);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7464
  match(Set dst (CountLeadingZerosL src));
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7465
  effect(KILL cr);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7466
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7467
  format %{ "bsrq    $dst, $src\t# count leading zeros (long)\n\t"
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7468
            "jnz     skip\n\t"
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7469
            "movl    $dst, -1\n"
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7470
      "skip:\n\t"
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7471
            "negl    $dst\n\t"
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7472
            "addl    $dst, 63" %}
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7473
  ins_encode %{
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7474
    Register Rdst = $dst$$Register;
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7475
    Register Rsrc = $src$$Register;
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7476
    Label skip;
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7477
    __ bsrq(Rdst, Rsrc);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7478
    __ jccb(Assembler::notZero, skip);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7479
    __ movl(Rdst, -1);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7480
    __ bind(skip);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7481
    __ negl(Rdst);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7482
    __ addl(Rdst, BitsPerLong - 1);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7483
  %}
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7484
  ins_pipe(ialu_reg);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7485
%}
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7486
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7487
instruct countTrailingZerosI(rRegI dst, rRegI src, rFlagsReg cr) %{
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7488
  match(Set dst (CountTrailingZerosI src));
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7489
  effect(KILL cr);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7490
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7491
  format %{ "bsfl    $dst, $src\t# count trailing zeros (int)\n\t"
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7492
            "jnz     done\n\t"
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7493
            "movl    $dst, 32\n"
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7494
      "done:" %}
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7495
  ins_encode %{
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7496
    Register Rdst = $dst$$Register;
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7497
    Label done;
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7498
    __ bsfl(Rdst, $src$$Register);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7499
    __ jccb(Assembler::notZero, done);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7500
    __ movl(Rdst, BitsPerInt);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7501
    __ bind(done);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7502
  %}
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7503
  ins_pipe(ialu_reg);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7504
%}
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7505
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7506
instruct countTrailingZerosL(rRegI dst, rRegL src, rFlagsReg cr) %{
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7507
  match(Set dst (CountTrailingZerosL src));
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7508
  effect(KILL cr);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7509
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7510
  format %{ "bsfq    $dst, $src\t# count trailing zeros (long)\n\t"
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7511
            "jnz     done\n\t"
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7512
            "movl    $dst, 64\n"
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7513
      "done:" %}
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7514
  ins_encode %{
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7515
    Register Rdst = $dst$$Register;
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7516
    Label done;
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7517
    __ bsfq(Rdst, $src$$Register);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7518
    __ jccb(Assembler::notZero, done);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7519
    __ movl(Rdst, BitsPerLong);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7520
    __ bind(done);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7521
  %}
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7522
  ins_pipe(ialu_reg);
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7523
%}
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7524
fad636edf18f 6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents: 2348
diff changeset
  7525
2255
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2254
diff changeset
  7526
//---------- Population Count Instructions -------------------------------------
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2254
diff changeset
  7527
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2254
diff changeset
  7528
instruct popCountI(rRegI dst, rRegI src) %{
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2254
diff changeset
  7529
  predicate(UsePopCountInstruction);
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2254
diff changeset
  7530
  match(Set dst (PopCountI src));
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2254
diff changeset
  7531
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2254
diff changeset
  7532
  format %{ "popcnt  $dst, $src" %}
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2254
diff changeset
  7533
  ins_encode %{
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2254
diff changeset
  7534
    __ popcntl($dst$$Register, $src$$Register);
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2254
diff changeset
  7535
  %}
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2254
diff changeset
  7536
  ins_pipe(ialu_reg);
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2254
diff changeset
  7537
%}
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2254
diff changeset
  7538
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2254
diff changeset
  7539
instruct popCountI_mem(rRegI dst, memory mem) %{
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2254
diff changeset
  7540
  predicate(UsePopCountInstruction);
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2254
diff changeset
  7541
  match(Set dst (PopCountI (LoadI mem)));
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2254
diff changeset
  7542
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2254
diff changeset
  7543
  format %{ "popcnt  $dst, $mem" %}
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2254
diff changeset
  7544
  ins_encode %{
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2254
diff changeset
  7545
    __ popcntl($dst$$Register, $mem$$Address);
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2254
diff changeset
  7546
  %}
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2254
diff changeset
  7547
  ins_pipe(ialu_reg);
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2254
diff changeset
  7548
%}
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2254
diff changeset
  7549
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2254
diff changeset
  7550
// Note: Long.bitCount(long) returns an int.
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2254
diff changeset
  7551
instruct popCountL(rRegI dst, rRegL src) %{
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2254
diff changeset
  7552
  predicate(UsePopCountInstruction);
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2254
diff changeset
  7553
  match(Set dst (PopCountL src));
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2254
diff changeset
  7554
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2254
diff changeset
  7555
  format %{ "popcnt  $dst, $src" %}
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2254
diff changeset
  7556
  ins_encode %{
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2254
diff changeset
  7557
    __ popcntq($dst$$Register, $src$$Register);
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2254
diff changeset
  7558
  %}
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2254
diff changeset
  7559
  ins_pipe(ialu_reg);
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2254
diff changeset
  7560
%}
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2254
diff changeset
  7561
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2254
diff changeset
  7562
// Note: Long.bitCount(long) returns an int.
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2254
diff changeset
  7563
instruct popCountL_mem(rRegI dst, memory mem) %{
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2254
diff changeset
  7564
  predicate(UsePopCountInstruction);
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2254
diff changeset
  7565
  match(Set dst (PopCountL (LoadL mem)));
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2254
diff changeset
  7566
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2254
diff changeset
  7567
  format %{ "popcnt  $dst, $mem" %}
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2254
diff changeset
  7568
  ins_encode %{
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2254
diff changeset
  7569
    __ popcntq($dst$$Register, $mem$$Address);
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2254
diff changeset
  7570
  %}
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2254
diff changeset
  7571
  ins_pipe(ialu_reg);
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2254
diff changeset
  7572
%}
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2254
diff changeset
  7573
54abdf3e1055 6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents: 2254
diff changeset
  7574
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7575
//----------MemBar Instructions-----------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7576
// Memory barrier flavors
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7577
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7578
instruct membar_acquire()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7579
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7580
  match(MemBarAcquire);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7581
  ins_cost(0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7582
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7583
  size(0);
2338
a8660a1b709b 6822204: volatile fences should prefer lock:addl to actual mfence instructions
never
parents: 2259
diff changeset
  7584
  format %{ "MEMBAR-acquire ! (empty encoding)" %}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7585
  ins_encode();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7586
  ins_pipe(empty);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7587
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7588
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7589
instruct membar_acquire_lock()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7590
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7591
  match(MemBarAcquire);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7592
  predicate(Matcher::prior_fast_lock(n));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7593
  ins_cost(0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7594
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7595
  size(0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7596
  format %{ "MEMBAR-acquire (prior CMPXCHG in FastLock so empty encoding)" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7597
  ins_encode();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7598
  ins_pipe(empty);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7599
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7600
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7601
instruct membar_release()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7602
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7603
  match(MemBarRelease);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7604
  ins_cost(0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7605
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7606
  size(0);
2338
a8660a1b709b 6822204: volatile fences should prefer lock:addl to actual mfence instructions
never
parents: 2259
diff changeset
  7607
  format %{ "MEMBAR-release ! (empty encoding)" %}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7608
  ins_encode();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7609
  ins_pipe(empty);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7610
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7611
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7612
instruct membar_release_lock()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7613
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7614
  match(MemBarRelease);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7615
  predicate(Matcher::post_fast_unlock(n));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7616
  ins_cost(0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7617
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7618
  size(0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7619
  format %{ "MEMBAR-release (a FastUnlock follows so empty encoding)" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7620
  ins_encode();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7621
  ins_pipe(empty);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7622
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7623
2338
a8660a1b709b 6822204: volatile fences should prefer lock:addl to actual mfence instructions
never
parents: 2259
diff changeset
  7624
instruct membar_volatile(rFlagsReg cr) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7625
  match(MemBarVolatile);
2338
a8660a1b709b 6822204: volatile fences should prefer lock:addl to actual mfence instructions
never
parents: 2259
diff changeset
  7626
  effect(KILL cr);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7627
  ins_cost(400);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7628
2338
a8660a1b709b 6822204: volatile fences should prefer lock:addl to actual mfence instructions
never
parents: 2259
diff changeset
  7629
  format %{ 
a8660a1b709b 6822204: volatile fences should prefer lock:addl to actual mfence instructions
never
parents: 2259
diff changeset
  7630
    $$template
a8660a1b709b 6822204: volatile fences should prefer lock:addl to actual mfence instructions
never
parents: 2259
diff changeset
  7631
    if (os::is_MP()) {
a8660a1b709b 6822204: volatile fences should prefer lock:addl to actual mfence instructions
never
parents: 2259
diff changeset
  7632
      $$emit$$"lock addl [rsp + #0], 0\t! membar_volatile"
a8660a1b709b 6822204: volatile fences should prefer lock:addl to actual mfence instructions
never
parents: 2259
diff changeset
  7633
    } else {
a8660a1b709b 6822204: volatile fences should prefer lock:addl to actual mfence instructions
never
parents: 2259
diff changeset
  7634
      $$emit$$"MEMBAR-volatile ! (empty encoding)"
a8660a1b709b 6822204: volatile fences should prefer lock:addl to actual mfence instructions
never
parents: 2259
diff changeset
  7635
    }
a8660a1b709b 6822204: volatile fences should prefer lock:addl to actual mfence instructions
never
parents: 2259
diff changeset
  7636
  %}
a8660a1b709b 6822204: volatile fences should prefer lock:addl to actual mfence instructions
never
parents: 2259
diff changeset
  7637
  ins_encode %{
a8660a1b709b 6822204: volatile fences should prefer lock:addl to actual mfence instructions
never
parents: 2259
diff changeset
  7638
    __ membar(Assembler::StoreLoad);
a8660a1b709b 6822204: volatile fences should prefer lock:addl to actual mfence instructions
never
parents: 2259
diff changeset
  7639
  %}
1
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
instruct unnecessary_membar_volatile()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7644
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7645
  match(MemBarVolatile);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7646
  predicate(Matcher::post_store_load_barrier(n));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7647
  ins_cost(0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7648
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7649
  size(0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7650
  format %{ "MEMBAR-volatile (unnecessary so empty encoding)" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7651
  ins_encode();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7652
  ins_pipe(empty);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7653
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7654
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7655
//----------Move Instructions--------------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7656
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7657
instruct castX2P(rRegP dst, rRegL src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7658
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7659
  match(Set dst (CastX2P src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7660
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7661
  format %{ "movq    $dst, $src\t# long->ptr" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7662
  ins_encode(enc_copy_wide(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7663
  ins_pipe(ialu_reg_reg); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7664
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7665
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7666
instruct castP2X(rRegL dst, rRegP src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7667
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7668
  match(Set dst (CastP2X src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7669
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7670
  format %{ "movq    $dst, $src\t# ptr -> long" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7671
  ins_encode(enc_copy_wide(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7672
  ins_pipe(ialu_reg_reg); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7673
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7674
360
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  7675
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  7676
// Convert oop pointer into compressed form
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  7677
instruct encodeHeapOop(rRegN dst, rRegP src, rFlagsReg cr) %{
767
64fb1fd7186d 6710487: More than half of JDI Regression tests hang with COOPs in -Xcomp mode
kvn
parents: 608
diff changeset
  7678
  predicate(n->bottom_type()->make_ptr()->ptr() != TypePtr::NotNull);
360
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  7679
  match(Set dst (EncodeP src));
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  7680
  effect(KILL cr);
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  7681
  format %{ "encode_heap_oop $dst,$src" %}
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  7682
  ins_encode %{
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  7683
    Register s = $src$$Register;
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  7684
    Register d = $dst$$Register;
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  7685
    if (s != d) {
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  7686
      __ movq(d, s);
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  7687
    }
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  7688
    __ encode_heap_oop(d);
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  7689
  %}
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  7690
  ins_pipe(ialu_reg_long);
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  7691
%}
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  7692
371
1aacedc9db7c 6689060: Escape Analysis does not work with Compressed Oops
kvn
parents: 360
diff changeset
  7693
instruct encodeHeapOop_not_null(rRegN dst, rRegP src, rFlagsReg cr) %{
767
64fb1fd7186d 6710487: More than half of JDI Regression tests hang with COOPs in -Xcomp mode
kvn
parents: 608
diff changeset
  7694
  predicate(n->bottom_type()->make_ptr()->ptr() == TypePtr::NotNull);
371
1aacedc9db7c 6689060: Escape Analysis does not work with Compressed Oops
kvn
parents: 360
diff changeset
  7695
  match(Set dst (EncodeP src));
1aacedc9db7c 6689060: Escape Analysis does not work with Compressed Oops
kvn
parents: 360
diff changeset
  7696
  effect(KILL cr);
1aacedc9db7c 6689060: Escape Analysis does not work with Compressed Oops
kvn
parents: 360
diff changeset
  7697
  format %{ "encode_heap_oop_not_null $dst,$src" %}
1aacedc9db7c 6689060: Escape Analysis does not work with Compressed Oops
kvn
parents: 360
diff changeset
  7698
  ins_encode %{
2254
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7699
    __ encode_heap_oop_not_null($dst$$Register, $src$$Register);
371
1aacedc9db7c 6689060: Escape Analysis does not work with Compressed Oops
kvn
parents: 360
diff changeset
  7700
  %}
1aacedc9db7c 6689060: Escape Analysis does not work with Compressed Oops
kvn
parents: 360
diff changeset
  7701
  ins_pipe(ialu_reg_long);
1aacedc9db7c 6689060: Escape Analysis does not work with Compressed Oops
kvn
parents: 360
diff changeset
  7702
%}
1aacedc9db7c 6689060: Escape Analysis does not work with Compressed Oops
kvn
parents: 360
diff changeset
  7703
360
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  7704
instruct decodeHeapOop(rRegP dst, rRegN src, rFlagsReg cr) %{
608
fe8c5fbbc54e 6709093: Compressed Oops: reduce size of compiled methods
kvn
parents: 595
diff changeset
  7705
  predicate(n->bottom_type()->is_oopptr()->ptr() != TypePtr::NotNull &&
fe8c5fbbc54e 6709093: Compressed Oops: reduce size of compiled methods
kvn
parents: 595
diff changeset
  7706
            n->bottom_type()->is_oopptr()->ptr() != TypePtr::Constant);
360
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  7707
  match(Set dst (DecodeN src));
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  7708
  effect(KILL cr);
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  7709
  format %{ "decode_heap_oop $dst,$src" %}
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  7710
  ins_encode %{
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  7711
    Register s = $src$$Register;
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  7712
    Register d = $dst$$Register;
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  7713
    if (s != d) {
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  7714
      __ movq(d, s);
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  7715
    }
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  7716
    __ decode_heap_oop(d);
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  7717
  %}
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  7718
  ins_pipe(ialu_reg_long);
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  7719
%}
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  7720
371
1aacedc9db7c 6689060: Escape Analysis does not work with Compressed Oops
kvn
parents: 360
diff changeset
  7721
instruct decodeHeapOop_not_null(rRegP dst, rRegN src) %{
608
fe8c5fbbc54e 6709093: Compressed Oops: reduce size of compiled methods
kvn
parents: 595
diff changeset
  7722
  predicate(n->bottom_type()->is_oopptr()->ptr() == TypePtr::NotNull ||
fe8c5fbbc54e 6709093: Compressed Oops: reduce size of compiled methods
kvn
parents: 595
diff changeset
  7723
            n->bottom_type()->is_oopptr()->ptr() == TypePtr::Constant);
371
1aacedc9db7c 6689060: Escape Analysis does not work with Compressed Oops
kvn
parents: 360
diff changeset
  7724
  match(Set dst (DecodeN src));
1aacedc9db7c 6689060: Escape Analysis does not work with Compressed Oops
kvn
parents: 360
diff changeset
  7725
  format %{ "decode_heap_oop_not_null $dst,$src" %}
1aacedc9db7c 6689060: Escape Analysis does not work with Compressed Oops
kvn
parents: 360
diff changeset
  7726
  ins_encode %{
1aacedc9db7c 6689060: Escape Analysis does not work with Compressed Oops
kvn
parents: 360
diff changeset
  7727
    Register s = $src$$Register;
1aacedc9db7c 6689060: Escape Analysis does not work with Compressed Oops
kvn
parents: 360
diff changeset
  7728
    Register d = $dst$$Register;
2254
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7729
    if (s != d) {
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7730
      __ decode_heap_oop_not_null(d, s);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7731
    } else {
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7732
      __ decode_heap_oop_not_null(d);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
  7733
    }
371
1aacedc9db7c 6689060: Escape Analysis does not work with Compressed Oops
kvn
parents: 360
diff changeset
  7734
  %}
1aacedc9db7c 6689060: Escape Analysis does not work with Compressed Oops
kvn
parents: 360
diff changeset
  7735
  ins_pipe(ialu_reg_long);
1aacedc9db7c 6689060: Escape Analysis does not work with Compressed Oops
kvn
parents: 360
diff changeset
  7736
%}
1aacedc9db7c 6689060: Escape Analysis does not work with Compressed Oops
kvn
parents: 360
diff changeset
  7737
360
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  7738
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7739
//----------Conditional Move---------------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7740
// Jump
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7741
// dummy instruction for generating temp registers
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7742
instruct jumpXtnd_offset(rRegL switch_val, immI2 shift, rRegI dest) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7743
  match(Jump (LShiftL switch_val shift));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7744
  ins_cost(350);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7745
  predicate(false);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7746
  effect(TEMP dest);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7747
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7748
  format %{ "leaq    $dest, table_base\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7749
            "jmp     [$dest + $switch_val << $shift]\n\t" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7750
  ins_encode(jump_enc_offset(switch_val, shift, dest));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7751
  ins_pipe(pipe_jmp);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7752
  ins_pc_relative(1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7753
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7754
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7755
instruct jumpXtnd_addr(rRegL switch_val, immI2 shift, immL32 offset, rRegI dest) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7756
  match(Jump (AddL (LShiftL switch_val shift) offset));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7757
  ins_cost(350);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7758
  effect(TEMP dest);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7759
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7760
  format %{ "leaq    $dest, table_base\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7761
            "jmp     [$dest + $switch_val << $shift + $offset]\n\t" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7762
  ins_encode(jump_enc_addr(switch_val, shift, offset, dest));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7763
  ins_pipe(pipe_jmp);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7764
  ins_pc_relative(1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7765
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7766
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7767
instruct jumpXtnd(rRegL switch_val, rRegI dest) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7768
  match(Jump switch_val);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7769
  ins_cost(350);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7770
  effect(TEMP dest);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7771
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7772
  format %{ "leaq    $dest, table_base\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7773
            "jmp     [$dest + $switch_val]\n\t" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7774
  ins_encode(jump_enc(switch_val, dest));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7775
  ins_pipe(pipe_jmp);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7776
  ins_pc_relative(1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7777
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7778
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7779
// Conditional move
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7780
instruct cmovI_reg(rRegI dst, rRegI src, rFlagsReg cr, cmpOp cop)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7781
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7782
  match(Set dst (CMoveI (Binary cop cr) (Binary dst src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7783
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7784
  ins_cost(200); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7785
  format %{ "cmovl$cop $dst, $src\t# signed, int" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7786
  opcode(0x0F, 0x40);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7787
  ins_encode(REX_reg_reg(dst, src), enc_cmov(cop), reg_reg(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7788
  ins_pipe(pipe_cmov_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7789
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7790
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  7791
instruct cmovI_regU(cmpOpU cop, rFlagsRegU cr, rRegI dst, rRegI src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7792
  match(Set dst (CMoveI (Binary cop cr) (Binary dst src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7793
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7794
  ins_cost(200); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7795
  format %{ "cmovl$cop $dst, $src\t# unsigned, int" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7796
  opcode(0x0F, 0x40);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7797
  ins_encode(REX_reg_reg(dst, src), enc_cmov(cop), reg_reg(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7798
  ins_pipe(pipe_cmov_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7799
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7800
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  7801
instruct cmovI_regUCF(cmpOpUCF cop, rFlagsRegUCF cr, rRegI dst, rRegI src) %{
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  7802
  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
  7803
  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
  7804
  expand %{
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  7805
    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
  7806
  %}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  7807
%}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  7808
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7809
// 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
  7810
instruct cmovI_mem(cmpOp cop, rFlagsReg cr, rRegI dst, memory src) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7811
  match(Set dst (CMoveI (Binary cop cr) (Binary dst (LoadI src))));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7812
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7813
  ins_cost(250); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7814
  format %{ "cmovl$cop $dst, $src\t# signed, int" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7815
  opcode(0x0F, 0x40);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7816
  ins_encode(REX_reg_mem(dst, src), enc_cmov(cop), reg_mem(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7817
  ins_pipe(pipe_cmov_mem);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7818
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7819
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7820
// Conditional move
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7821
instruct cmovI_memU(cmpOpU cop, rFlagsRegU cr, rRegI dst, memory src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7822
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7823
  match(Set dst (CMoveI (Binary cop cr) (Binary dst (LoadI src))));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7824
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7825
  ins_cost(250); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7826
  format %{ "cmovl$cop $dst, $src\t# unsigned, int" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7827
  opcode(0x0F, 0x40);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7828
  ins_encode(REX_reg_mem(dst, src), enc_cmov(cop), reg_mem(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7829
  ins_pipe(pipe_cmov_mem);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7830
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7831
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  7832
instruct cmovI_memUCF(cmpOpUCF cop, rFlagsRegUCF cr, rRegI dst, memory src) %{
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  7833
  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
  7834
  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
  7835
  expand %{
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  7836
    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
  7837
  %}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  7838
%}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  7839
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7840
// Conditional move
590
2954744d7bba 6703890: Compressed Oops: add LoadNKlass node to generate narrow oops (32-bits) compare instructions
kvn
parents: 589
diff changeset
  7841
instruct cmovN_reg(rRegN dst, rRegN src, rFlagsReg cr, cmpOp cop)
2954744d7bba 6703890: Compressed Oops: add LoadNKlass node to generate narrow oops (32-bits) compare instructions
kvn
parents: 589
diff changeset
  7842
%{
2954744d7bba 6703890: Compressed Oops: add LoadNKlass node to generate narrow oops (32-bits) compare instructions
kvn
parents: 589
diff changeset
  7843
  match(Set dst (CMoveN (Binary cop cr) (Binary dst src)));
2954744d7bba 6703890: Compressed Oops: add LoadNKlass node to generate narrow oops (32-bits) compare instructions
kvn
parents: 589
diff changeset
  7844
2954744d7bba 6703890: Compressed Oops: add LoadNKlass node to generate narrow oops (32-bits) compare instructions
kvn
parents: 589
diff changeset
  7845
  ins_cost(200); // XXX
2954744d7bba 6703890: Compressed Oops: add LoadNKlass node to generate narrow oops (32-bits) compare instructions
kvn
parents: 589
diff changeset
  7846
  format %{ "cmovl$cop $dst, $src\t# signed, compressed ptr" %}
2954744d7bba 6703890: Compressed Oops: add LoadNKlass node to generate narrow oops (32-bits) compare instructions
kvn
parents: 589
diff changeset
  7847
  opcode(0x0F, 0x40);
2954744d7bba 6703890: Compressed Oops: add LoadNKlass node to generate narrow oops (32-bits) compare instructions
kvn
parents: 589
diff changeset
  7848
  ins_encode(REX_reg_reg(dst, src), enc_cmov(cop), reg_reg(dst, src));
2954744d7bba 6703890: Compressed Oops: add LoadNKlass node to generate narrow oops (32-bits) compare instructions
kvn
parents: 589
diff changeset
  7849
  ins_pipe(pipe_cmov_reg);
2954744d7bba 6703890: Compressed Oops: add LoadNKlass node to generate narrow oops (32-bits) compare instructions
kvn
parents: 589
diff changeset
  7850
%}
2954744d7bba 6703890: Compressed Oops: add LoadNKlass node to generate narrow oops (32-bits) compare instructions
kvn
parents: 589
diff changeset
  7851
2954744d7bba 6703890: Compressed Oops: add LoadNKlass node to generate narrow oops (32-bits) compare instructions
kvn
parents: 589
diff changeset
  7852
// 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
  7853
instruct cmovN_regU(cmpOpU cop, rFlagsRegU cr, rRegN dst, rRegN src)
590
2954744d7bba 6703890: Compressed Oops: add LoadNKlass node to generate narrow oops (32-bits) compare instructions
kvn
parents: 589
diff changeset
  7854
%{
2954744d7bba 6703890: Compressed Oops: add LoadNKlass node to generate narrow oops (32-bits) compare instructions
kvn
parents: 589
diff changeset
  7855
  match(Set dst (CMoveN (Binary cop cr) (Binary dst src)));
2954744d7bba 6703890: Compressed Oops: add LoadNKlass node to generate narrow oops (32-bits) compare instructions
kvn
parents: 589
diff changeset
  7856
2954744d7bba 6703890: Compressed Oops: add LoadNKlass node to generate narrow oops (32-bits) compare instructions
kvn
parents: 589
diff changeset
  7857
  ins_cost(200); // XXX
2954744d7bba 6703890: Compressed Oops: add LoadNKlass node to generate narrow oops (32-bits) compare instructions
kvn
parents: 589
diff changeset
  7858
  format %{ "cmovl$cop $dst, $src\t# unsigned, compressed ptr" %}
2954744d7bba 6703890: Compressed Oops: add LoadNKlass node to generate narrow oops (32-bits) compare instructions
kvn
parents: 589
diff changeset
  7859
  opcode(0x0F, 0x40);
2954744d7bba 6703890: Compressed Oops: add LoadNKlass node to generate narrow oops (32-bits) compare instructions
kvn
parents: 589
diff changeset
  7860
  ins_encode(REX_reg_reg(dst, src), enc_cmov(cop), reg_reg(dst, src));
2954744d7bba 6703890: Compressed Oops: add LoadNKlass node to generate narrow oops (32-bits) compare instructions
kvn
parents: 589
diff changeset
  7861
  ins_pipe(pipe_cmov_reg);
2954744d7bba 6703890: Compressed Oops: add LoadNKlass node to generate narrow oops (32-bits) compare instructions
kvn
parents: 589
diff changeset
  7862
%}
2954744d7bba 6703890: Compressed Oops: add LoadNKlass node to generate narrow oops (32-bits) compare instructions
kvn
parents: 589
diff changeset
  7863
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  7864
instruct cmovN_regUCF(cmpOpUCF cop, rFlagsRegUCF cr, rRegN dst, rRegN src) %{
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  7865
  match(Set dst (CMoveN (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
  7866
  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
  7867
  expand %{
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  7868
    cmovN_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
  7869
  %}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  7870
%}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  7871
590
2954744d7bba 6703890: Compressed Oops: add LoadNKlass node to generate narrow oops (32-bits) compare instructions
kvn
parents: 589
diff changeset
  7872
// Conditional move
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7873
instruct cmovP_reg(rRegP dst, rRegP src, rFlagsReg cr, cmpOp cop)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7874
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7875
  match(Set dst (CMoveP (Binary cop cr) (Binary dst src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7876
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7877
  ins_cost(200); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7878
  format %{ "cmovq$cop $dst, $src\t# signed, ptr" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7879
  opcode(0x0F, 0x40);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7880
  ins_encode(REX_reg_reg_wide(dst, src), enc_cmov(cop), reg_reg(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7881
  ins_pipe(pipe_cmov_reg);  // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7882
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7883
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7884
// 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
  7885
instruct cmovP_regU(cmpOpU cop, rFlagsRegU cr, rRegP dst, rRegP src)
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7886
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7887
  match(Set dst (CMoveP (Binary cop cr) (Binary dst src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7888
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7889
  ins_cost(200); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7890
  format %{ "cmovq$cop $dst, $src\t# unsigned, ptr" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7891
  opcode(0x0F, 0x40);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7892
  ins_encode(REX_reg_reg_wide(dst, src), enc_cmov(cop), reg_reg(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7893
  ins_pipe(pipe_cmov_reg); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7894
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7895
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  7896
instruct cmovP_regUCF(cmpOpUCF cop, rFlagsRegUCF cr, rRegP dst, rRegP src) %{
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  7897
  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
  7898
  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
  7899
  expand %{
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  7900
    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
  7901
  %}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  7902
%}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  7903
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7904
// DISABLED: Requires the ADLC to emit a bottom_type call that
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7905
// correctly meets the two pointer arguments; one is an incoming
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7906
// register but the other is a memory operand.  ALSO appears to
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7907
// be buggy with implicit null checks.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7908
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7909
//// Conditional move
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7910
//instruct cmovP_mem(cmpOp cop, rFlagsReg cr, rRegP dst, memory src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7911
//%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7912
//  match(Set dst (CMoveP (Binary cop cr) (Binary dst (LoadP src))));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7913
//  ins_cost(250);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7914
//  format %{ "CMOV$cop $dst,$src\t# ptr" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7915
//  opcode(0x0F,0x40);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7916
//  ins_encode( enc_cmov(cop), reg_mem( dst, src ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7917
//  ins_pipe( pipe_cmov_mem );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7918
//%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7919
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7920
//// Conditional move
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7921
//instruct cmovP_memU(cmpOpU cop, rFlagsRegU cr, rRegP dst, memory src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7922
//%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7923
//  match(Set dst (CMoveP (Binary cop cr) (Binary dst (LoadP src))));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7924
//  ins_cost(250);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7925
//  format %{ "CMOV$cop $dst,$src\t# ptr" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7926
//  opcode(0x0F,0x40);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7927
//  ins_encode( enc_cmov(cop), reg_mem( dst, src ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7928
//  ins_pipe( pipe_cmov_mem );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7929
//%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7930
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7931
instruct cmovL_reg(cmpOp cop, rFlagsReg cr, rRegL dst, rRegL src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7932
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7933
  match(Set dst (CMoveL (Binary cop cr) (Binary dst src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7934
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7935
  ins_cost(200); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7936
  format %{ "cmovq$cop $dst, $src\t# signed, long" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7937
  opcode(0x0F, 0x40);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7938
  ins_encode(REX_reg_reg_wide(dst, src), enc_cmov(cop), reg_reg(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7939
  ins_pipe(pipe_cmov_reg);  // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7940
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7941
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7942
instruct cmovL_mem(cmpOp cop, rFlagsReg cr, rRegL dst, memory src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7943
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7944
  match(Set dst (CMoveL (Binary cop cr) (Binary dst (LoadL src))));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7945
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7946
  ins_cost(200); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7947
  format %{ "cmovq$cop $dst, $src\t# signed, long" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7948
  opcode(0x0F, 0x40);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7949
  ins_encode(REX_reg_mem_wide(dst, src), enc_cmov(cop), reg_mem(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7950
  ins_pipe(pipe_cmov_mem);  // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7951
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7952
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7953
instruct cmovL_regU(cmpOpU cop, rFlagsRegU cr, rRegL dst, rRegL src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7954
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7955
  match(Set dst (CMoveL (Binary cop cr) (Binary dst src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7956
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7957
  ins_cost(200); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7958
  format %{ "cmovq$cop $dst, $src\t# unsigned, long" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7959
  opcode(0x0F, 0x40);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7960
  ins_encode(REX_reg_reg_wide(dst, src), enc_cmov(cop), reg_reg(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7961
  ins_pipe(pipe_cmov_reg); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7962
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7963
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  7964
instruct cmovL_regUCF(cmpOpUCF cop, rFlagsRegUCF cr, rRegL dst, rRegL src) %{
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  7965
  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
  7966
  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
  7967
  expand %{
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  7968
    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
  7969
  %}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  7970
%}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  7971
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7972
instruct cmovL_memU(cmpOpU cop, rFlagsRegU cr, rRegL dst, memory src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7973
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7974
  match(Set dst (CMoveL (Binary cop cr) (Binary dst (LoadL src))));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7975
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7976
  ins_cost(200); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7977
  format %{ "cmovq$cop $dst, $src\t# unsigned, long" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7978
  opcode(0x0F, 0x40);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7979
  ins_encode(REX_reg_mem_wide(dst, src), enc_cmov(cop), reg_mem(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7980
  ins_pipe(pipe_cmov_mem); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7981
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7982
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  7983
instruct cmovL_memUCF(cmpOpUCF cop, rFlagsRegUCF cr, rRegL dst, memory src) %{
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  7984
  match(Set dst (CMoveL (Binary cop cr) (Binary dst (LoadL src))));
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  7985
  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
  7986
  expand %{
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  7987
    cmovL_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
  7988
  %}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  7989
%}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  7990
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7991
instruct cmovF_reg(cmpOp cop, rFlagsReg cr, regF dst, regF src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7992
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7993
  match(Set dst (CMoveF (Binary cop cr) (Binary dst src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7994
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7995
  ins_cost(200); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7996
  format %{ "jn$cop    skip\t# signed cmove float\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7997
            "movss     $dst, $src\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7998
    "skip:" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  7999
  ins_encode(enc_cmovf_branch(cop, dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8000
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8001
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8002
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8003
// instruct cmovF_mem(cmpOp cop, rFlagsReg cr, regF dst, memory src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8004
// %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8005
//   match(Set dst (CMoveF (Binary cop cr) (Binary dst (LoadL src))));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8006
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8007
//   ins_cost(200); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8008
//   format %{ "jn$cop    skip\t# signed cmove float\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8009
//             "movss     $dst, $src\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8010
//     "skip:" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8011
//   ins_encode(enc_cmovf_mem_branch(cop, dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8012
//   ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8013
// %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8014
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8015
instruct cmovF_regU(cmpOpU cop, rFlagsRegU cr, regF dst, regF src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8016
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8017
  match(Set dst (CMoveF (Binary cop cr) (Binary dst src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8018
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8019
  ins_cost(200); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8020
  format %{ "jn$cop    skip\t# unsigned cmove float\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8021
            "movss     $dst, $src\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8022
    "skip:" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8023
  ins_encode(enc_cmovf_branch(cop, dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8024
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8025
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8026
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  8027
instruct cmovF_regUCF(cmpOpUCF cop, rFlagsRegUCF cr, regF dst, regF src) %{
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  8028
  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
  8029
  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
  8030
  expand %{
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  8031
    cmovF_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
  8032
  %}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  8033
%}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  8034
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8035
instruct cmovD_reg(cmpOp cop, rFlagsReg cr, regD dst, regD src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8036
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8037
  match(Set dst (CMoveD (Binary cop cr) (Binary dst src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8038
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8039
  ins_cost(200); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8040
  format %{ "jn$cop    skip\t# signed cmove double\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8041
            "movsd     $dst, $src\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8042
    "skip:" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8043
  ins_encode(enc_cmovd_branch(cop, dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8044
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8045
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8046
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8047
instruct cmovD_regU(cmpOpU cop, rFlagsRegU cr, regD dst, regD src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8048
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8049
  match(Set dst (CMoveD (Binary cop cr) (Binary dst src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8050
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8051
  ins_cost(200); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8052
  format %{ "jn$cop    skip\t# unsigned cmove double\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8053
            "movsd     $dst, $src\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8054
    "skip:" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8055
  ins_encode(enc_cmovd_branch(cop, dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8056
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8057
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8058
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  8059
instruct cmovD_regUCF(cmpOpUCF cop, rFlagsRegUCF cr, regD dst, regD src) %{
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  8060
  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
  8061
  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
  8062
  expand %{
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  8063
    cmovD_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
  8064
  %}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  8065
%}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
  8066
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8067
//----------Arithmetic Instructions--------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8068
//----------Addition Instructions----------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8069
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8070
instruct addI_rReg(rRegI dst, rRegI src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8071
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8072
  match(Set dst (AddI dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8073
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8074
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8075
  format %{ "addl    $dst, $src\t# int" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8076
  opcode(0x03);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8077
  ins_encode(REX_reg_reg(dst, src), OpcP, reg_reg(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8078
  ins_pipe(ialu_reg_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8079
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8080
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8081
instruct addI_rReg_imm(rRegI dst, immI src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8082
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8083
  match(Set dst (AddI dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8084
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8085
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8086
  format %{ "addl    $dst, $src\t# int" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8087
  opcode(0x81, 0x00); /* /0 id */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8088
  ins_encode(OpcSErm(dst, src), Con8or32(src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8089
  ins_pipe( ialu_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8090
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8091
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8092
instruct addI_rReg_mem(rRegI dst, memory src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8093
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8094
  match(Set dst (AddI dst (LoadI src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8095
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8096
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8097
  ins_cost(125); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8098
  format %{ "addl    $dst, $src\t# int" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8099
  opcode(0x03);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8100
  ins_encode(REX_reg_mem(dst, src), OpcP, reg_mem(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8101
  ins_pipe(ialu_reg_mem);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8102
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8103
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8104
instruct addI_mem_rReg(memory dst, rRegI src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8105
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8106
  match(Set dst (StoreI dst (AddI (LoadI dst) src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8107
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8108
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8109
  ins_cost(150); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8110
  format %{ "addl    $dst, $src\t# int" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8111
  opcode(0x01); /* Opcode 01 /r */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8112
  ins_encode(REX_reg_mem(src, dst), OpcP, reg_mem(src, dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8113
  ins_pipe(ialu_mem_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8114
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8115
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8116
instruct addI_mem_imm(memory dst, immI src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8117
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8118
  match(Set dst (StoreI dst (AddI (LoadI dst) src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8119
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8120
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8121
  ins_cost(125); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8122
  format %{ "addl    $dst, $src\t# int" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8123
  opcode(0x81); /* Opcode 81 /0 id */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8124
  ins_encode(REX_mem(dst), OpcSE(src), RM_opc_mem(0x00, dst), Con8or32(src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8125
  ins_pipe(ialu_mem_imm);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8126
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8127
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8128
instruct incI_rReg(rRegI dst, immI1 src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8129
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8130
  predicate(UseIncDec);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8131
  match(Set dst (AddI dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8132
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8133
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8134
  format %{ "incl    $dst\t# int" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8135
  opcode(0xFF, 0x00); // FF /0
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8136
  ins_encode(REX_reg(dst), OpcP, reg_opc(dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8137
  ins_pipe(ialu_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8138
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8139
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8140
instruct incI_mem(memory dst, immI1 src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8141
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8142
  predicate(UseIncDec);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8143
  match(Set dst (StoreI dst (AddI (LoadI dst) src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8144
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8145
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8146
  ins_cost(125); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8147
  format %{ "incl    $dst\t# int" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8148
  opcode(0xFF); /* Opcode FF /0 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8149
  ins_encode(REX_mem(dst), OpcP, RM_opc_mem(0x00, dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8150
  ins_pipe(ialu_mem_imm);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8151
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8152
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8153
// XXX why does that use AddI
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8154
instruct decI_rReg(rRegI dst, immI_M1 src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8155
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8156
  predicate(UseIncDec);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8157
  match(Set dst (AddI dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8158
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8159
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8160
  format %{ "decl    $dst\t# int" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8161
  opcode(0xFF, 0x01); // FF /1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8162
  ins_encode(REX_reg(dst), OpcP, reg_opc(dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8163
  ins_pipe(ialu_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8164
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8165
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8166
// XXX why does that use AddI
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8167
instruct decI_mem(memory dst, immI_M1 src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8168
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8169
  predicate(UseIncDec);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8170
  match(Set dst (StoreI dst (AddI (LoadI dst) src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8171
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8172
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8173
  ins_cost(125); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8174
  format %{ "decl    $dst\t# int" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8175
  opcode(0xFF); /* Opcode FF /1 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8176
  ins_encode(REX_mem(dst), OpcP, RM_opc_mem(0x01, dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8177
  ins_pipe(ialu_mem_imm);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8178
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8179
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8180
instruct leaI_rReg_immI(rRegI dst, rRegI src0, immI src1)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8181
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8182
  match(Set dst (AddI src0 src1));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8183
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8184
  ins_cost(110);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8185
  format %{ "addr32 leal $dst, [$src0 + $src1]\t# int" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8186
  opcode(0x8D); /* 0x8D /r */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8187
  ins_encode(Opcode(0x67), REX_reg_reg(dst, src0), OpcP, reg_lea(dst, src0, src1)); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8188
  ins_pipe(ialu_reg_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8189
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8190
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8191
instruct addL_rReg(rRegL dst, rRegL src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8192
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8193
  match(Set dst (AddL dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8194
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8195
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8196
  format %{ "addq    $dst, $src\t# long" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8197
  opcode(0x03);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8198
  ins_encode(REX_reg_reg_wide(dst, src), OpcP, reg_reg(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8199
  ins_pipe(ialu_reg_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8200
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8201
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8202
instruct addL_rReg_imm(rRegL dst, immL32 src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8203
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8204
  match(Set dst (AddL dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8205
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8206
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8207
  format %{ "addq    $dst, $src\t# long" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8208
  opcode(0x81, 0x00); /* /0 id */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8209
  ins_encode(OpcSErm_wide(dst, src), Con8or32(src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8210
  ins_pipe( ialu_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8211
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8212
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8213
instruct addL_rReg_mem(rRegL dst, memory src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8214
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8215
  match(Set dst (AddL dst (LoadL src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8216
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8217
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8218
  ins_cost(125); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8219
  format %{ "addq    $dst, $src\t# long" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8220
  opcode(0x03);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8221
  ins_encode(REX_reg_mem_wide(dst, src), OpcP, reg_mem(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8222
  ins_pipe(ialu_reg_mem);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8223
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8224
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8225
instruct addL_mem_rReg(memory dst, rRegL src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8226
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8227
  match(Set dst (StoreL dst (AddL (LoadL dst) src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8228
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8229
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8230
  ins_cost(150); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8231
  format %{ "addq    $dst, $src\t# long" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8232
  opcode(0x01); /* Opcode 01 /r */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8233
  ins_encode(REX_reg_mem_wide(src, dst), OpcP, reg_mem(src, dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8234
  ins_pipe(ialu_mem_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8235
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8236
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8237
instruct addL_mem_imm(memory dst, immL32 src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8238
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8239
  match(Set dst (StoreL dst (AddL (LoadL dst) src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8240
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8241
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8242
  ins_cost(125); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8243
  format %{ "addq    $dst, $src\t# long" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8244
  opcode(0x81); /* Opcode 81 /0 id */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8245
  ins_encode(REX_mem_wide(dst),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8246
             OpcSE(src), RM_opc_mem(0x00, dst), Con8or32(src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8247
  ins_pipe(ialu_mem_imm);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8248
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8249
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8250
instruct incL_rReg(rRegI dst, immL1 src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8251
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8252
  predicate(UseIncDec);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8253
  match(Set dst (AddL dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8254
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8255
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8256
  format %{ "incq    $dst\t# long" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8257
  opcode(0xFF, 0x00); // FF /0
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8258
  ins_encode(REX_reg_wide(dst), OpcP, reg_opc(dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8259
  ins_pipe(ialu_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8260
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8261
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8262
instruct incL_mem(memory dst, immL1 src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8263
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8264
  predicate(UseIncDec);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8265
  match(Set dst (StoreL dst (AddL (LoadL dst) src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8266
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8267
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8268
  ins_cost(125); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8269
  format %{ "incq    $dst\t# long" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8270
  opcode(0xFF); /* Opcode FF /0 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8271
  ins_encode(REX_mem_wide(dst), OpcP, RM_opc_mem(0x00, dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8272
  ins_pipe(ialu_mem_imm);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8273
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8274
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8275
// XXX why does that use AddL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8276
instruct decL_rReg(rRegL dst, immL_M1 src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8277
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8278
  predicate(UseIncDec);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8279
  match(Set dst (AddL dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8280
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8281
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8282
  format %{ "decq    $dst\t# long" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8283
  opcode(0xFF, 0x01); // FF /1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8284
  ins_encode(REX_reg_wide(dst), OpcP, reg_opc(dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8285
  ins_pipe(ialu_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8286
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8287
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8288
// XXX why does that use AddL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8289
instruct decL_mem(memory dst, immL_M1 src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8290
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8291
  predicate(UseIncDec);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8292
  match(Set dst (StoreL dst (AddL (LoadL dst) src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8293
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8294
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8295
  ins_cost(125); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8296
  format %{ "decq    $dst\t# long" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8297
  opcode(0xFF); /* Opcode FF /1 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8298
  ins_encode(REX_mem_wide(dst), OpcP, RM_opc_mem(0x01, dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8299
  ins_pipe(ialu_mem_imm);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8300
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8301
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8302
instruct leaL_rReg_immL(rRegL dst, rRegL src0, immL32 src1)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8303
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8304
  match(Set dst (AddL src0 src1));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8305
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8306
  ins_cost(110);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8307
  format %{ "leaq    $dst, [$src0 + $src1]\t# long" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8308
  opcode(0x8D); /* 0x8D /r */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8309
  ins_encode(REX_reg_reg_wide(dst, src0), OpcP, reg_lea(dst, src0, src1)); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8310
  ins_pipe(ialu_reg_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8311
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8312
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8313
instruct addP_rReg(rRegP dst, rRegL src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8314
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8315
  match(Set dst (AddP dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8316
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8317
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8318
  format %{ "addq    $dst, $src\t# ptr" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8319
  opcode(0x03);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8320
  ins_encode(REX_reg_reg_wide(dst, src), OpcP, reg_reg(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8321
  ins_pipe(ialu_reg_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8322
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8323
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8324
instruct addP_rReg_imm(rRegP dst, immL32 src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8325
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8326
  match(Set dst (AddP dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8327
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8328
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8329
  format %{ "addq    $dst, $src\t# ptr" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8330
  opcode(0x81, 0x00); /* /0 id */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8331
  ins_encode(OpcSErm_wide(dst, src), Con8or32(src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8332
  ins_pipe( ialu_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8333
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8334
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8335
// XXX addP mem ops ????
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8336
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8337
instruct leaP_rReg_imm(rRegP dst, rRegP src0, immL32 src1)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8338
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8339
  match(Set dst (AddP src0 src1));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8340
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8341
  ins_cost(110);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8342
  format %{ "leaq    $dst, [$src0 + $src1]\t# ptr" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8343
  opcode(0x8D); /* 0x8D /r */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8344
  ins_encode(REX_reg_reg_wide(dst, src0), OpcP, reg_lea(dst, src0, src1));// XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8345
  ins_pipe(ialu_reg_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8346
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8347
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8348
instruct checkCastPP(rRegP dst)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8349
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8350
  match(Set dst (CheckCastPP dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8351
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8352
  size(0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8353
  format %{ "# checkcastPP of $dst" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8354
  ins_encode(/* empty encoding */);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8355
  ins_pipe(empty);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8356
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8357
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8358
instruct castPP(rRegP dst)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8359
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8360
  match(Set dst (CastPP dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8361
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8362
  size(0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8363
  format %{ "# castPP of $dst" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8364
  ins_encode(/* empty encoding */);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8365
  ins_pipe(empty);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8366
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8367
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8368
instruct castII(rRegI dst)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8369
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8370
  match(Set dst (CastII dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8371
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8372
  size(0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8373
  format %{ "# castII of $dst" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8374
  ins_encode(/* empty encoding */);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8375
  ins_cost(0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8376
  ins_pipe(empty);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8377
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8378
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8379
// LoadP-locked same as a regular LoadP when used with compare-swap
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8380
instruct loadPLocked(rRegP dst, memory mem)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8381
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8382
  match(Set dst (LoadPLocked mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8383
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8384
  ins_cost(125); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8385
  format %{ "movq    $dst, $mem\t# ptr locked" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8386
  opcode(0x8B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8387
  ins_encode(REX_reg_mem_wide(dst, mem), OpcP, reg_mem(dst, mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8388
  ins_pipe(ialu_reg_mem); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8389
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8390
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8391
// LoadL-locked - same as a regular LoadL when used with compare-swap
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8392
instruct loadLLocked(rRegL dst, memory mem)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8393
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8394
  match(Set dst (LoadLLocked mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8395
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8396
  ins_cost(125); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8397
  format %{ "movq    $dst, $mem\t# long locked" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8398
  opcode(0x8B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8399
  ins_encode(REX_reg_mem_wide(dst, mem), OpcP, reg_mem(dst, mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8400
  ins_pipe(ialu_reg_mem); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8401
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8402
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8403
// Conditional-store of the updated heap-top.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8404
// Used during allocation of the shared heap.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8405
// Sets flags (EQ) on success.  Implemented with a CMPXCHG on Intel.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8406
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8407
instruct storePConditional(memory heap_top_ptr,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8408
                           rax_RegP oldval, rRegP newval,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8409
                           rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8410
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8411
  match(Set cr (StorePConditional heap_top_ptr (Binary oldval newval)));
1500
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
  8412
 
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8413
  format %{ "cmpxchgq $heap_top_ptr, $newval\t# (ptr) "
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8414
            "If rax == $heap_top_ptr then store $newval into $heap_top_ptr" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8415
  opcode(0x0F, 0xB1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8416
  ins_encode(lock_prefix,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8417
             REX_reg_mem_wide(newval, heap_top_ptr),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8418
             OpcP, OpcS,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8419
             reg_mem(newval, heap_top_ptr));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8420
  ins_pipe(pipe_cmpxchg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8421
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8422
1500
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
  8423
// Conditional-store of an int value.
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
  8424
// ZF flag is set on success, reset otherwise.  Implemented with a CMPXCHG.
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
  8425
instruct storeIConditional(memory mem, rax_RegI oldval, rRegI newval, rFlagsReg cr)
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
  8426
%{
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
  8427
  match(Set cr (StoreIConditional mem (Binary oldval newval)));
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
  8428
  effect(KILL oldval);
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
  8429
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
  8430
  format %{ "cmpxchgl $mem, $newval\t# If rax == $mem then store $newval into $mem" %}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8431
  opcode(0x0F, 0xB1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8432
  ins_encode(lock_prefix,
1500
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
  8433
             REX_reg_mem(newval, mem),
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8434
             OpcP, OpcS,
1500
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
  8435
             reg_mem(newval, mem));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8436
  ins_pipe(pipe_cmpxchg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8437
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8438
1500
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
  8439
// Conditional-store of a long value.
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
  8440
// ZF flag is set on success, reset otherwise.  Implemented with a CMPXCHG.
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
  8441
instruct storeLConditional(memory mem, rax_RegL oldval, rRegL newval, rFlagsReg cr)
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
  8442
%{
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
  8443
  match(Set cr (StoreLConditional mem (Binary oldval newval)));
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
  8444
  effect(KILL oldval);
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
  8445
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
  8446
  format %{ "cmpxchgq $mem, $newval\t# If rax == $mem then store $newval into $mem" %}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8447
  opcode(0x0F, 0xB1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8448
  ins_encode(lock_prefix,
1500
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
  8449
             REX_reg_mem_wide(newval, mem),
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8450
             OpcP, OpcS,
1500
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
  8451
             reg_mem(newval, mem));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8452
  ins_pipe(pipe_cmpxchg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8453
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8454
1500
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
  8455
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
  8456
// XXX No flag versions for CompareAndSwap{P,I,L} because matcher can't match them
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8457
instruct compareAndSwapP(rRegI res,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8458
                         memory mem_ptr,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8459
                         rax_RegP oldval, rRegP newval,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8460
                         rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8461
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8462
  match(Set res (CompareAndSwapP mem_ptr (Binary oldval newval)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8463
  effect(KILL cr, KILL oldval);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8464
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8465
  format %{ "cmpxchgq $mem_ptr,$newval\t# "
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8466
            "If rax == $mem_ptr then store $newval into $mem_ptr\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8467
            "sete    $res\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8468
            "movzbl  $res, $res" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8469
  opcode(0x0F, 0xB1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8470
  ins_encode(lock_prefix,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8471
             REX_reg_mem_wide(newval, mem_ptr),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8472
             OpcP, OpcS,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8473
             reg_mem(newval, mem_ptr),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8474
             REX_breg(res), Opcode(0x0F), Opcode(0x94), reg(res), // sete
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8475
             REX_reg_breg(res, res), // movzbl
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8476
             Opcode(0xF), Opcode(0xB6), reg_reg(res, res));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8477
  ins_pipe( pipe_cmpxchg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8478
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8479
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8480
instruct compareAndSwapL(rRegI res,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8481
                         memory mem_ptr,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8482
                         rax_RegL oldval, rRegL newval,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8483
                         rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8484
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8485
  match(Set res (CompareAndSwapL mem_ptr (Binary oldval newval)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8486
  effect(KILL cr, KILL oldval);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8487
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8488
  format %{ "cmpxchgq $mem_ptr,$newval\t# "
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8489
            "If rax == $mem_ptr then store $newval into $mem_ptr\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8490
            "sete    $res\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8491
            "movzbl  $res, $res" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8492
  opcode(0x0F, 0xB1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8493
  ins_encode(lock_prefix,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8494
             REX_reg_mem_wide(newval, mem_ptr),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8495
             OpcP, OpcS,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8496
             reg_mem(newval, mem_ptr),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8497
             REX_breg(res), Opcode(0x0F), Opcode(0x94), reg(res), // sete
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8498
             REX_reg_breg(res, res), // movzbl
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8499
             Opcode(0xF), Opcode(0xB6), reg_reg(res, res));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8500
  ins_pipe( pipe_cmpxchg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8501
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8502
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8503
instruct compareAndSwapI(rRegI res,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8504
                         memory mem_ptr,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8505
                         rax_RegI oldval, rRegI newval,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8506
                         rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8507
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8508
  match(Set res (CompareAndSwapI mem_ptr (Binary oldval newval)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8509
  effect(KILL cr, KILL oldval);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8510
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8511
  format %{ "cmpxchgl $mem_ptr,$newval\t# "
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8512
            "If rax == $mem_ptr then store $newval into $mem_ptr\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8513
            "sete    $res\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8514
            "movzbl  $res, $res" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8515
  opcode(0x0F, 0xB1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8516
  ins_encode(lock_prefix,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8517
             REX_reg_mem(newval, mem_ptr),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8518
             OpcP, OpcS,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8519
             reg_mem(newval, mem_ptr),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8520
             REX_breg(res), Opcode(0x0F), Opcode(0x94), reg(res), // sete
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8521
             REX_reg_breg(res, res), // movzbl
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8522
             Opcode(0xF), Opcode(0xB6), reg_reg(res, res));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8523
  ins_pipe( pipe_cmpxchg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8524
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8525
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8526
360
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  8527
instruct compareAndSwapN(rRegI res,
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  8528
                          memory mem_ptr,
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  8529
                          rax_RegN oldval, rRegN newval,
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  8530
                          rFlagsReg cr) %{
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  8531
  match(Set res (CompareAndSwapN mem_ptr (Binary oldval newval)));
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  8532
  effect(KILL cr, KILL oldval);
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  8533
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  8534
  format %{ "cmpxchgl $mem_ptr,$newval\t# "
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  8535
            "If rax == $mem_ptr then store $newval into $mem_ptr\n\t"
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  8536
            "sete    $res\n\t"
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  8537
            "movzbl  $res, $res" %}
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  8538
  opcode(0x0F, 0xB1);
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  8539
  ins_encode(lock_prefix,
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  8540
             REX_reg_mem(newval, mem_ptr),
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  8541
             OpcP, OpcS,
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  8542
             reg_mem(newval, mem_ptr),
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  8543
             REX_breg(res), Opcode(0x0F), Opcode(0x94), reg(res), // sete
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  8544
             REX_reg_breg(res, res), // movzbl
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  8545
             Opcode(0xF), Opcode(0xB6), reg_reg(res, res));
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  8546
  ins_pipe( pipe_cmpxchg );
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  8547
%}
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
  8548
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8549
//----------Subtraction Instructions-------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8550
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8551
// Integer Subtraction Instructions
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8552
instruct subI_rReg(rRegI dst, rRegI src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8553
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8554
  match(Set dst (SubI dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8555
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8556
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8557
  format %{ "subl    $dst, $src\t# int" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8558
  opcode(0x2B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8559
  ins_encode(REX_reg_reg(dst, src), OpcP, reg_reg(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8560
  ins_pipe(ialu_reg_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8561
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8562
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8563
instruct subI_rReg_imm(rRegI dst, immI src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8564
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8565
  match(Set dst (SubI dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8566
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8567
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8568
  format %{ "subl    $dst, $src\t# int" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8569
  opcode(0x81, 0x05);  /* Opcode 81 /5 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8570
  ins_encode(OpcSErm(dst, src), Con8or32(src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8571
  ins_pipe(ialu_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8572
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8573
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8574
instruct subI_rReg_mem(rRegI dst, memory src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8575
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8576
  match(Set dst (SubI dst (LoadI src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8577
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8578
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8579
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8580
  format %{ "subl    $dst, $src\t# int" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8581
  opcode(0x2B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8582
  ins_encode(REX_reg_mem(dst, src), OpcP, reg_mem(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8583
  ins_pipe(ialu_reg_mem);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8584
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8585
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8586
instruct subI_mem_rReg(memory dst, rRegI src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8587
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8588
  match(Set dst (StoreI dst (SubI (LoadI dst) src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8589
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8590
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8591
  ins_cost(150);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8592
  format %{ "subl    $dst, $src\t# int" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8593
  opcode(0x29); /* Opcode 29 /r */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8594
  ins_encode(REX_reg_mem(src, dst), OpcP, reg_mem(src, dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8595
  ins_pipe(ialu_mem_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8596
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8597
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8598
instruct subI_mem_imm(memory dst, immI src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8599
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8600
  match(Set dst (StoreI dst (SubI (LoadI dst) src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8601
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8602
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8603
  ins_cost(125); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8604
  format %{ "subl    $dst, $src\t# int" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8605
  opcode(0x81); /* Opcode 81 /5 id */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8606
  ins_encode(REX_mem(dst), OpcSE(src), RM_opc_mem(0x05, dst), Con8or32(src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8607
  ins_pipe(ialu_mem_imm);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8608
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8609
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8610
instruct subL_rReg(rRegL dst, rRegL src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8611
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8612
  match(Set dst (SubL dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8613
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8614
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8615
  format %{ "subq    $dst, $src\t# long" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8616
  opcode(0x2B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8617
  ins_encode(REX_reg_reg_wide(dst, src), OpcP, reg_reg(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8618
  ins_pipe(ialu_reg_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8619
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8620
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8621
instruct subL_rReg_imm(rRegI dst, immL32 src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8622
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8623
  match(Set dst (SubL dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8624
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8625
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8626
  format %{ "subq    $dst, $src\t# long" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8627
  opcode(0x81, 0x05);  /* Opcode 81 /5 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8628
  ins_encode(OpcSErm_wide(dst, src), Con8or32(src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8629
  ins_pipe(ialu_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8630
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8631
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8632
instruct subL_rReg_mem(rRegL dst, memory src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8633
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8634
  match(Set dst (SubL dst (LoadL src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8635
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8636
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8637
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8638
  format %{ "subq    $dst, $src\t# long" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8639
  opcode(0x2B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8640
  ins_encode(REX_reg_mem_wide(dst, src), OpcP, reg_mem(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8641
  ins_pipe(ialu_reg_mem);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8642
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8643
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8644
instruct subL_mem_rReg(memory dst, rRegL src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8645
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8646
  match(Set dst (StoreL dst (SubL (LoadL dst) src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8647
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8648
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8649
  ins_cost(150);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8650
  format %{ "subq    $dst, $src\t# long" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8651
  opcode(0x29); /* Opcode 29 /r */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8652
  ins_encode(REX_reg_mem_wide(src, dst), OpcP, reg_mem(src, dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8653
  ins_pipe(ialu_mem_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8654
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8655
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8656
instruct subL_mem_imm(memory dst, immL32 src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8657
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8658
  match(Set dst (StoreL dst (SubL (LoadL dst) src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8659
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8660
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8661
  ins_cost(125); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8662
  format %{ "subq    $dst, $src\t# long" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8663
  opcode(0x81); /* Opcode 81 /5 id */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8664
  ins_encode(REX_mem_wide(dst),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8665
             OpcSE(src), RM_opc_mem(0x05, dst), Con8or32(src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8666
  ins_pipe(ialu_mem_imm);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8667
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8668
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8669
// Subtract from a pointer
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8670
// XXX hmpf???
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8671
instruct subP_rReg(rRegP dst, rRegI src, immI0 zero, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8672
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8673
  match(Set dst (AddP dst (SubI zero src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8674
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8675
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8676
  format %{ "subq    $dst, $src\t# ptr - int" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8677
  opcode(0x2B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8678
  ins_encode(REX_reg_reg_wide(dst, src), OpcP, reg_reg(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8679
  ins_pipe(ialu_reg_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8680
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8681
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8682
instruct negI_rReg(rRegI dst, immI0 zero, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8683
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8684
  match(Set dst (SubI zero dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8685
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8686
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8687
  format %{ "negl    $dst\t# int" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8688
  opcode(0xF7, 0x03);  // Opcode F7 /3
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8689
  ins_encode(REX_reg(dst), OpcP, reg_opc(dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8690
  ins_pipe(ialu_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8691
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8692
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8693
instruct negI_mem(memory dst, immI0 zero, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8694
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8695
  match(Set dst (StoreI dst (SubI zero (LoadI dst))));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8696
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8697
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8698
  format %{ "negl    $dst\t# int" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8699
  opcode(0xF7, 0x03);  // Opcode F7 /3
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8700
  ins_encode(REX_mem(dst), OpcP, RM_opc_mem(secondary, dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8701
  ins_pipe(ialu_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8702
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8703
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8704
instruct negL_rReg(rRegL dst, immL0 zero, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8705
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8706
  match(Set dst (SubL zero dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8707
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8708
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8709
  format %{ "negq    $dst\t# long" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8710
  opcode(0xF7, 0x03);  // Opcode F7 /3
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8711
  ins_encode(REX_reg_wide(dst), OpcP, reg_opc(dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8712
  ins_pipe(ialu_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8713
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8714
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8715
instruct negL_mem(memory dst, immL0 zero, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8716
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8717
  match(Set dst (StoreL dst (SubL zero (LoadL dst))));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8718
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8719
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8720
  format %{ "negq    $dst\t# long" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8721
  opcode(0xF7, 0x03);  // Opcode F7 /3
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8722
  ins_encode(REX_mem_wide(dst), OpcP, RM_opc_mem(secondary, dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8723
  ins_pipe(ialu_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8724
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8725
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8726
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8727
//----------Multiplication/Division Instructions-------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8728
// Integer Multiplication Instructions
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8729
// Multiply Register
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8730
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8731
instruct mulI_rReg(rRegI dst, rRegI src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8732
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8733
  match(Set dst (MulI dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8734
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8735
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8736
  ins_cost(300);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8737
  format %{ "imull   $dst, $src\t# int" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8738
  opcode(0x0F, 0xAF);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8739
  ins_encode(REX_reg_reg(dst, src), OpcP, OpcS, reg_reg(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8740
  ins_pipe(ialu_reg_reg_alu0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8741
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8742
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8743
instruct mulI_rReg_imm(rRegI dst, rRegI src, immI imm, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8744
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8745
  match(Set dst (MulI src imm));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8746
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8747
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8748
  ins_cost(300);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8749
  format %{ "imull   $dst, $src, $imm\t# int" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8750
  opcode(0x69); /* 69 /r id */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8751
  ins_encode(REX_reg_reg(dst, src),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8752
             OpcSE(imm), reg_reg(dst, src), Con8or32(imm));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8753
  ins_pipe(ialu_reg_reg_alu0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8754
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8755
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8756
instruct mulI_mem(rRegI dst, memory src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8757
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8758
  match(Set dst (MulI dst (LoadI src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8759
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8760
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8761
  ins_cost(350);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8762
  format %{ "imull   $dst, $src\t# int" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8763
  opcode(0x0F, 0xAF);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8764
  ins_encode(REX_reg_mem(dst, src), OpcP, OpcS, reg_mem(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8765
  ins_pipe(ialu_reg_mem_alu0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8766
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8767
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8768
instruct mulI_mem_imm(rRegI dst, memory src, immI imm, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8769
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8770
  match(Set dst (MulI (LoadI src) imm));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8771
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8772
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8773
  ins_cost(300);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8774
  format %{ "imull   $dst, $src, $imm\t# int" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8775
  opcode(0x69); /* 69 /r id */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8776
  ins_encode(REX_reg_mem(dst, src),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8777
             OpcSE(imm), reg_mem(dst, src), Con8or32(imm));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8778
  ins_pipe(ialu_reg_mem_alu0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8779
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8780
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8781
instruct mulL_rReg(rRegL dst, rRegL src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8782
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8783
  match(Set dst (MulL dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8784
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8785
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8786
  ins_cost(300);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8787
  format %{ "imulq   $dst, $src\t# long" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8788
  opcode(0x0F, 0xAF);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8789
  ins_encode(REX_reg_reg_wide(dst, src), OpcP, OpcS, reg_reg(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8790
  ins_pipe(ialu_reg_reg_alu0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8791
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8792
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8793
instruct mulL_rReg_imm(rRegL dst, rRegL src, immL32 imm, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8794
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8795
  match(Set dst (MulL src imm));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8796
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8797
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8798
  ins_cost(300);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8799
  format %{ "imulq   $dst, $src, $imm\t# long" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8800
  opcode(0x69); /* 69 /r id */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8801
  ins_encode(REX_reg_reg_wide(dst, src),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8802
             OpcSE(imm), reg_reg(dst, src), Con8or32(imm));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8803
  ins_pipe(ialu_reg_reg_alu0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8804
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8805
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8806
instruct mulL_mem(rRegL dst, memory src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8807
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8808
  match(Set dst (MulL dst (LoadL src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8809
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8810
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8811
  ins_cost(350);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8812
  format %{ "imulq   $dst, $src\t# long" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8813
  opcode(0x0F, 0xAF);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8814
  ins_encode(REX_reg_mem_wide(dst, src), OpcP, OpcS, reg_mem(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8815
  ins_pipe(ialu_reg_mem_alu0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8816
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8817
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8818
instruct mulL_mem_imm(rRegL dst, memory src, immL32 imm, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8819
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8820
  match(Set dst (MulL (LoadL src) imm));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8821
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8822
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8823
  ins_cost(300);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8824
  format %{ "imulq   $dst, $src, $imm\t# long" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8825
  opcode(0x69); /* 69 /r id */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8826
  ins_encode(REX_reg_mem_wide(dst, src),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8827
             OpcSE(imm), reg_mem(dst, src), Con8or32(imm));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8828
  ins_pipe(ialu_reg_mem_alu0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8829
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8830
392
0b3167e2f2de 6603011: RFE: Optimize long division
rasbold
parents: 371
diff changeset
  8831
instruct mulHiL_rReg(rdx_RegL dst, no_rax_RegL src, rax_RegL rax, rFlagsReg cr)
0b3167e2f2de 6603011: RFE: Optimize long division
rasbold
parents: 371
diff changeset
  8832
%{
0b3167e2f2de 6603011: RFE: Optimize long division
rasbold
parents: 371
diff changeset
  8833
  match(Set dst (MulHiL src rax));
0b3167e2f2de 6603011: RFE: Optimize long division
rasbold
parents: 371
diff changeset
  8834
  effect(USE_KILL rax, KILL cr);
0b3167e2f2de 6603011: RFE: Optimize long division
rasbold
parents: 371
diff changeset
  8835
0b3167e2f2de 6603011: RFE: Optimize long division
rasbold
parents: 371
diff changeset
  8836
  ins_cost(300);
0b3167e2f2de 6603011: RFE: Optimize long division
rasbold
parents: 371
diff changeset
  8837
  format %{ "imulq   RDX:RAX, RAX, $src\t# mulhi" %}
0b3167e2f2de 6603011: RFE: Optimize long division
rasbold
parents: 371
diff changeset
  8838
  opcode(0xF7, 0x5); /* Opcode F7 /5 */
0b3167e2f2de 6603011: RFE: Optimize long division
rasbold
parents: 371
diff changeset
  8839
  ins_encode(REX_reg_wide(src), OpcP, reg_opc(src));
0b3167e2f2de 6603011: RFE: Optimize long division
rasbold
parents: 371
diff changeset
  8840
  ins_pipe(ialu_reg_reg_alu0);
0b3167e2f2de 6603011: RFE: Optimize long division
rasbold
parents: 371
diff changeset
  8841
%}
0b3167e2f2de 6603011: RFE: Optimize long division
rasbold
parents: 371
diff changeset
  8842
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8843
instruct divI_rReg(rax_RegI rax, rdx_RegI rdx, no_rax_rdx_RegI div,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8844
                   rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8845
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8846
  match(Set rax (DivI rax div));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8847
  effect(KILL rdx, KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8848
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8849
  ins_cost(30*100+10*100); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8850
  format %{ "cmpl    rax, 0x80000000\t# idiv\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8851
            "jne,s   normal\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8852
            "xorl    rdx, rdx\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8853
            "cmpl    $div, -1\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8854
            "je,s    done\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8855
    "normal: cdql\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8856
            "idivl   $div\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8857
    "done:"        %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8858
  opcode(0xF7, 0x7);  /* Opcode F7 /7 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8859
  ins_encode(cdql_enc(div), REX_reg(div), OpcP, reg_opc(div));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8860
  ins_pipe(ialu_reg_reg_alu0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8861
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8862
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8863
instruct divL_rReg(rax_RegL rax, rdx_RegL rdx, no_rax_rdx_RegL div,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8864
                   rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8865
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8866
  match(Set rax (DivL rax div));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8867
  effect(KILL rdx, KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8868
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8869
  ins_cost(30*100+10*100); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8870
  format %{ "movq    rdx, 0x8000000000000000\t# ldiv\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8871
            "cmpq    rax, rdx\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8872
            "jne,s   normal\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8873
            "xorl    rdx, rdx\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8874
            "cmpq    $div, -1\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8875
            "je,s    done\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8876
    "normal: cdqq\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8877
            "idivq   $div\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8878
    "done:"        %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8879
  opcode(0xF7, 0x7);  /* Opcode F7 /7 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8880
  ins_encode(cdqq_enc(div), REX_reg_wide(div), OpcP, reg_opc(div));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8881
  ins_pipe(ialu_reg_reg_alu0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8882
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8883
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8884
// Integer DIVMOD with Register, both quotient and mod results
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8885
instruct divModI_rReg_divmod(rax_RegI rax, rdx_RegI rdx, no_rax_rdx_RegI div,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8886
                             rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8887
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8888
  match(DivModI rax div);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8889
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8890
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8891
  ins_cost(30*100+10*100); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8892
  format %{ "cmpl    rax, 0x80000000\t# idiv\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8893
            "jne,s   normal\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8894
            "xorl    rdx, rdx\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8895
            "cmpl    $div, -1\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8896
            "je,s    done\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8897
    "normal: cdql\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8898
            "idivl   $div\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8899
    "done:"        %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8900
  opcode(0xF7, 0x7);  /* Opcode F7 /7 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8901
  ins_encode(cdql_enc(div), REX_reg(div), OpcP, reg_opc(div));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8902
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8903
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8904
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8905
// Long DIVMOD with Register, both quotient and mod results
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8906
instruct divModL_rReg_divmod(rax_RegL rax, rdx_RegL rdx, no_rax_rdx_RegL div,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8907
                             rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8908
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8909
  match(DivModL rax div);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8910
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8911
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8912
  ins_cost(30*100+10*100); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8913
  format %{ "movq    rdx, 0x8000000000000000\t# ldiv\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8914
            "cmpq    rax, rdx\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8915
            "jne,s   normal\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8916
            "xorl    rdx, rdx\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8917
            "cmpq    $div, -1\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8918
            "je,s    done\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8919
    "normal: cdqq\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8920
            "idivq   $div\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8921
    "done:"        %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8922
  opcode(0xF7, 0x7);  /* Opcode F7 /7 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8923
  ins_encode(cdqq_enc(div), REX_reg_wide(div), OpcP, reg_opc(div));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8924
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8925
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8926
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8927
//----------- DivL-By-Constant-Expansions--------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8928
// DivI cases are handled by the compiler
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8929
2131
98f9cef66a34 6810672: Comment typos
twisti
parents: 2033
diff changeset
  8930
// Magic constant, reciprocal of 10
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8931
instruct loadConL_0x6666666666666667(rRegL dst)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8932
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8933
  effect(DEF dst);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8934
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8935
  format %{ "movq    $dst, #0x666666666666667\t# Used in div-by-10" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8936
  ins_encode(load_immL(dst, 0x6666666666666667));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8937
  ins_pipe(ialu_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8938
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8939
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8940
instruct mul_hi(rdx_RegL dst, no_rax_RegL src, rax_RegL rax, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8941
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8942
  effect(DEF dst, USE src, USE_KILL rax, KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8943
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8944
  format %{ "imulq   rdx:rax, rax, $src\t# Used in div-by-10" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8945
  opcode(0xF7, 0x5); /* Opcode F7 /5 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8946
  ins_encode(REX_reg_wide(src), OpcP, reg_opc(src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8947
  ins_pipe(ialu_reg_reg_alu0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8948
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8949
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8950
instruct sarL_rReg_63(rRegL dst, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8951
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8952
  effect(USE_DEF dst, KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8953
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8954
  format %{ "sarq    $dst, #63\t# Used in div-by-10" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8955
  opcode(0xC1, 0x7); /* C1 /7 ib */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8956
  ins_encode(reg_opc_imm_wide(dst, 0x3F));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8957
  ins_pipe(ialu_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8958
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8959
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8960
instruct sarL_rReg_2(rRegL dst, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8961
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8962
  effect(USE_DEF dst, KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8963
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8964
  format %{ "sarq    $dst, #2\t# Used in div-by-10" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8965
  opcode(0xC1, 0x7); /* C1 /7 ib */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8966
  ins_encode(reg_opc_imm_wide(dst, 0x2));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8967
  ins_pipe(ialu_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8968
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8969
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8970
instruct divL_10(rdx_RegL dst, no_rax_RegL src, immL10 div)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8971
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8972
  match(Set dst (DivL src div));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8973
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8974
  ins_cost((5+8)*100);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8975
  expand %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8976
    rax_RegL rax;                     // Killed temp
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8977
    rFlagsReg cr;                     // Killed
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8978
    loadConL_0x6666666666666667(rax); // movq  rax, 0x6666666666666667
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8979
    mul_hi(dst, src, rax, cr);        // mulq  rdx:rax <= rax * $src
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8980
    sarL_rReg_63(src, cr);            // sarq  src, 63
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8981
    sarL_rReg_2(dst, cr);             // sarq  rdx, 2
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8982
    subL_rReg(dst, src, cr);          // subl  rdx, src
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8983
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8984
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8985
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8986
//-----------------------------------------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8987
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8988
instruct modI_rReg(rdx_RegI rdx, rax_RegI rax, no_rax_rdx_RegI div,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8989
                   rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8990
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8991
  match(Set rdx (ModI rax div));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8992
  effect(KILL rax, KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8993
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8994
  ins_cost(300); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8995
  format %{ "cmpl    rax, 0x80000000\t# irem\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8996
            "jne,s   normal\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8997
            "xorl    rdx, rdx\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8998
            "cmpl    $div, -1\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  8999
            "je,s    done\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9000
    "normal: cdql\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9001
            "idivl   $div\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9002
    "done:"        %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9003
  opcode(0xF7, 0x7);  /* Opcode F7 /7 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9004
  ins_encode(cdql_enc(div), REX_reg(div), OpcP, reg_opc(div));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9005
  ins_pipe(ialu_reg_reg_alu0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9006
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9007
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9008
instruct modL_rReg(rdx_RegL rdx, rax_RegL rax, no_rax_rdx_RegL div,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9009
                   rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9010
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9011
  match(Set rdx (ModL rax div));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9012
  effect(KILL rax, KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9013
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9014
  ins_cost(300); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9015
  format %{ "movq    rdx, 0x8000000000000000\t# lrem\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9016
            "cmpq    rax, rdx\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9017
            "jne,s   normal\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9018
            "xorl    rdx, rdx\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9019
            "cmpq    $div, -1\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9020
            "je,s    done\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9021
    "normal: cdqq\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9022
            "idivq   $div\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9023
    "done:"        %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9024
  opcode(0xF7, 0x7);  /* Opcode F7 /7 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9025
  ins_encode(cdqq_enc(div), REX_reg_wide(div), OpcP, reg_opc(div));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9026
  ins_pipe(ialu_reg_reg_alu0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9027
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9028
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9029
// Integer Shift Instructions
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9030
// Shift Left by one
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9031
instruct salI_rReg_1(rRegI dst, immI1 shift, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9032
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9033
  match(Set dst (LShiftI dst shift));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9034
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9035
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9036
  format %{ "sall    $dst, $shift" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9037
  opcode(0xD1, 0x4); /* D1 /4 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9038
  ins_encode(REX_reg(dst), OpcP, reg_opc(dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9039
  ins_pipe(ialu_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9040
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9041
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9042
// Shift Left by one
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9043
instruct salI_mem_1(memory dst, immI1 shift, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9044
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9045
  match(Set dst (StoreI dst (LShiftI (LoadI dst) shift)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9046
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9047
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9048
  format %{ "sall    $dst, $shift\t" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9049
  opcode(0xD1, 0x4); /* D1 /4 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9050
  ins_encode(REX_mem(dst), OpcP, RM_opc_mem(secondary, dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9051
  ins_pipe(ialu_mem_imm);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9052
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9053
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9054
// Shift Left by 8-bit immediate
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9055
instruct salI_rReg_imm(rRegI dst, immI8 shift, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9056
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9057
  match(Set dst (LShiftI dst shift));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9058
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9059
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9060
  format %{ "sall    $dst, $shift" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9061
  opcode(0xC1, 0x4); /* C1 /4 ib */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9062
  ins_encode(reg_opc_imm(dst, shift));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9063
  ins_pipe(ialu_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9064
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9065
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9066
// Shift Left by 8-bit immediate
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9067
instruct salI_mem_imm(memory dst, immI8 shift, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9068
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9069
  match(Set dst (StoreI dst (LShiftI (LoadI dst) shift)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9070
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9071
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9072
  format %{ "sall    $dst, $shift" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9073
  opcode(0xC1, 0x4); /* C1 /4 ib */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9074
  ins_encode(REX_mem(dst), OpcP, RM_opc_mem(secondary, dst), Con8or32(shift));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9075
  ins_pipe(ialu_mem_imm);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9076
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9077
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9078
// Shift Left by variable
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9079
instruct salI_rReg_CL(rRegI dst, rcx_RegI shift, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9080
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9081
  match(Set dst (LShiftI dst shift));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9082
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9083
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9084
  format %{ "sall    $dst, $shift" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9085
  opcode(0xD3, 0x4); /* D3 /4 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9086
  ins_encode(REX_reg(dst), OpcP, reg_opc(dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9087
  ins_pipe(ialu_reg_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9088
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9089
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9090
// Shift Left by variable
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9091
instruct salI_mem_CL(memory dst, rcx_RegI shift, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9092
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9093
  match(Set dst (StoreI dst (LShiftI (LoadI dst) shift)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9094
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9095
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9096
  format %{ "sall    $dst, $shift" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9097
  opcode(0xD3, 0x4); /* D3 /4 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9098
  ins_encode(REX_mem(dst), OpcP, RM_opc_mem(secondary, dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9099
  ins_pipe(ialu_mem_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9100
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9101
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9102
// Arithmetic shift right by one
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9103
instruct sarI_rReg_1(rRegI dst, immI1 shift, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9104
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9105
  match(Set dst (RShiftI dst shift));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9106
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9107
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9108
  format %{ "sarl    $dst, $shift" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9109
  opcode(0xD1, 0x7); /* D1 /7 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9110
  ins_encode(REX_reg(dst), OpcP, reg_opc(dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9111
  ins_pipe(ialu_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9112
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9113
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9114
// Arithmetic shift right by one
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9115
instruct sarI_mem_1(memory dst, immI1 shift, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9116
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9117
  match(Set dst (StoreI dst (RShiftI (LoadI dst) shift)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9118
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9119
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9120
  format %{ "sarl    $dst, $shift" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9121
  opcode(0xD1, 0x7); /* D1 /7 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9122
  ins_encode(REX_mem(dst), OpcP, RM_opc_mem(secondary, dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9123
  ins_pipe(ialu_mem_imm);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9124
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9125
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9126
// Arithmetic Shift Right by 8-bit immediate
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9127
instruct sarI_rReg_imm(rRegI dst, immI8 shift, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9128
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9129
  match(Set dst (RShiftI dst shift));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9130
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9131
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9132
  format %{ "sarl    $dst, $shift" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9133
  opcode(0xC1, 0x7); /* C1 /7 ib */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9134
  ins_encode(reg_opc_imm(dst, shift));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9135
  ins_pipe(ialu_mem_imm);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9136
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9137
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9138
// Arithmetic Shift Right by 8-bit immediate
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9139
instruct sarI_mem_imm(memory dst, immI8 shift, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9140
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9141
  match(Set dst (StoreI dst (RShiftI (LoadI dst) shift)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9142
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9143
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9144
  format %{ "sarl    $dst, $shift" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9145
  opcode(0xC1, 0x7); /* C1 /7 ib */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9146
  ins_encode(REX_mem(dst), OpcP, RM_opc_mem(secondary, dst), Con8or32(shift));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9147
  ins_pipe(ialu_mem_imm);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9148
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9149
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9150
// Arithmetic Shift Right by variable
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9151
instruct sarI_rReg_CL(rRegI dst, rcx_RegI shift, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9152
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9153
  match(Set dst (RShiftI dst shift));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9154
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9155
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9156
  format %{ "sarl    $dst, $shift" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9157
  opcode(0xD3, 0x7); /* D3 /7 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9158
  ins_encode(REX_reg(dst), OpcP, reg_opc(dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9159
  ins_pipe(ialu_reg_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9160
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9161
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9162
// Arithmetic Shift Right by variable
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9163
instruct sarI_mem_CL(memory dst, rcx_RegI shift, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9164
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9165
  match(Set dst (StoreI dst (RShiftI (LoadI dst) shift)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9166
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9167
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9168
  format %{ "sarl    $dst, $shift" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9169
  opcode(0xD3, 0x7); /* D3 /7 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9170
  ins_encode(REX_mem(dst), OpcP, RM_opc_mem(secondary, dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9171
  ins_pipe(ialu_mem_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9172
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9173
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9174
// Logical shift right by one
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9175
instruct shrI_rReg_1(rRegI dst, immI1 shift, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9176
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9177
  match(Set dst (URShiftI dst shift));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9178
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9179
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9180
  format %{ "shrl    $dst, $shift" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9181
  opcode(0xD1, 0x5); /* D1 /5 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9182
  ins_encode(REX_reg(dst), OpcP, reg_opc(dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9183
  ins_pipe(ialu_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9184
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9185
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9186
// Logical shift right by one
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9187
instruct shrI_mem_1(memory dst, immI1 shift, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9188
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9189
  match(Set dst (StoreI dst (URShiftI (LoadI dst) shift)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9190
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9191
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9192
  format %{ "shrl    $dst, $shift" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9193
  opcode(0xD1, 0x5); /* D1 /5 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9194
  ins_encode(REX_mem(dst), OpcP, RM_opc_mem(secondary, dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9195
  ins_pipe(ialu_mem_imm);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9196
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9197
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9198
// Logical Shift Right by 8-bit immediate
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9199
instruct shrI_rReg_imm(rRegI dst, immI8 shift, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9200
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9201
  match(Set dst (URShiftI dst shift));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9202
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9203
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9204
  format %{ "shrl    $dst, $shift" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9205
  opcode(0xC1, 0x5); /* C1 /5 ib */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9206
  ins_encode(reg_opc_imm(dst, shift));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9207
  ins_pipe(ialu_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9208
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9209
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9210
// Logical Shift Right by 8-bit immediate
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9211
instruct shrI_mem_imm(memory dst, immI8 shift, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9212
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9213
  match(Set dst (StoreI dst (URShiftI (LoadI dst) shift)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9214
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9215
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9216
  format %{ "shrl    $dst, $shift" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9217
  opcode(0xC1, 0x5); /* C1 /5 ib */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9218
  ins_encode(REX_mem(dst), OpcP, RM_opc_mem(secondary, dst), Con8or32(shift));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9219
  ins_pipe(ialu_mem_imm);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9220
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9221
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9222
// Logical Shift Right by variable
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9223
instruct shrI_rReg_CL(rRegI dst, rcx_RegI shift, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9224
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9225
  match(Set dst (URShiftI dst shift));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9226
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9227
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9228
  format %{ "shrl    $dst, $shift" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9229
  opcode(0xD3, 0x5); /* D3 /5 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9230
  ins_encode(REX_reg(dst), OpcP, reg_opc(dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9231
  ins_pipe(ialu_reg_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9232
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9233
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9234
// Logical Shift Right by variable
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9235
instruct shrI_mem_CL(memory dst, rcx_RegI shift, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9236
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9237
  match(Set dst (StoreI dst (URShiftI (LoadI dst) shift)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9238
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9239
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9240
  format %{ "shrl    $dst, $shift" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9241
  opcode(0xD3, 0x5); /* D3 /5 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9242
  ins_encode(REX_mem(dst), OpcP, RM_opc_mem(secondary, dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9243
  ins_pipe(ialu_mem_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9244
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9245
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9246
// Long Shift Instructions
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9247
// Shift Left by one
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9248
instruct salL_rReg_1(rRegL dst, immI1 shift, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9249
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9250
  match(Set dst (LShiftL dst shift));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9251
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9252
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9253
  format %{ "salq    $dst, $shift" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9254
  opcode(0xD1, 0x4); /* D1 /4 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9255
  ins_encode(REX_reg_wide(dst), OpcP, reg_opc(dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9256
  ins_pipe(ialu_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9257
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9258
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9259
// Shift Left by one
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9260
instruct salL_mem_1(memory dst, immI1 shift, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9261
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9262
  match(Set dst (StoreL dst (LShiftL (LoadL dst) shift)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9263
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9264
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9265
  format %{ "salq    $dst, $shift" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9266
  opcode(0xD1, 0x4); /* D1 /4 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9267
  ins_encode(REX_mem_wide(dst), OpcP, RM_opc_mem(secondary, dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9268
  ins_pipe(ialu_mem_imm);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9269
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9270
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9271
// Shift Left by 8-bit immediate
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9272
instruct salL_rReg_imm(rRegL dst, immI8 shift, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9273
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9274
  match(Set dst (LShiftL dst shift));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9275
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9276
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9277
  format %{ "salq    $dst, $shift" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9278
  opcode(0xC1, 0x4); /* C1 /4 ib */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9279
  ins_encode(reg_opc_imm_wide(dst, shift));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9280
  ins_pipe(ialu_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9281
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9282
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9283
// Shift Left by 8-bit immediate
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9284
instruct salL_mem_imm(memory dst, immI8 shift, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9285
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9286
  match(Set dst (StoreL dst (LShiftL (LoadL dst) shift)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9287
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9288
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9289
  format %{ "salq    $dst, $shift" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9290
  opcode(0xC1, 0x4); /* C1 /4 ib */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9291
  ins_encode(REX_mem_wide(dst), OpcP,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9292
             RM_opc_mem(secondary, dst), Con8or32(shift));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9293
  ins_pipe(ialu_mem_imm);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9294
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9295
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9296
// Shift Left by variable
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9297
instruct salL_rReg_CL(rRegL dst, rcx_RegI shift, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9298
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9299
  match(Set dst (LShiftL dst shift));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9300
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9301
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9302
  format %{ "salq    $dst, $shift" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9303
  opcode(0xD3, 0x4); /* D3 /4 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9304
  ins_encode(REX_reg_wide(dst), OpcP, reg_opc(dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9305
  ins_pipe(ialu_reg_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9306
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9307
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9308
// Shift Left by variable
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9309
instruct salL_mem_CL(memory dst, rcx_RegI shift, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9310
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9311
  match(Set dst (StoreL dst (LShiftL (LoadL dst) shift)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9312
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9313
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9314
  format %{ "salq    $dst, $shift" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9315
  opcode(0xD3, 0x4); /* D3 /4 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9316
  ins_encode(REX_mem_wide(dst), OpcP, RM_opc_mem(secondary, dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9317
  ins_pipe(ialu_mem_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9318
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9319
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9320
// Arithmetic shift right by one
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9321
instruct sarL_rReg_1(rRegL dst, immI1 shift, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9322
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9323
  match(Set dst (RShiftL dst shift));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9324
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9325
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9326
  format %{ "sarq    $dst, $shift" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9327
  opcode(0xD1, 0x7); /* D1 /7 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9328
  ins_encode(REX_reg_wide(dst), OpcP, reg_opc(dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9329
  ins_pipe(ialu_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9330
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9331
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9332
// Arithmetic shift right by one
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9333
instruct sarL_mem_1(memory dst, immI1 shift, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9334
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9335
  match(Set dst (StoreL dst (RShiftL (LoadL dst) shift)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9336
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9337
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9338
  format %{ "sarq    $dst, $shift" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9339
  opcode(0xD1, 0x7); /* D1 /7 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9340
  ins_encode(REX_mem_wide(dst), OpcP, RM_opc_mem(secondary, dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9341
  ins_pipe(ialu_mem_imm);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9342
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9343
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9344
// Arithmetic Shift Right by 8-bit immediate
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9345
instruct sarL_rReg_imm(rRegL dst, immI8 shift, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9346
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9347
  match(Set dst (RShiftL dst shift));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9348
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9349
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9350
  format %{ "sarq    $dst, $shift" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9351
  opcode(0xC1, 0x7); /* C1 /7 ib */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9352
  ins_encode(reg_opc_imm_wide(dst, shift));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9353
  ins_pipe(ialu_mem_imm);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9354
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9355
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9356
// Arithmetic Shift Right by 8-bit immediate
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9357
instruct sarL_mem_imm(memory dst, immI8 shift, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9358
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9359
  match(Set dst (StoreL dst (RShiftL (LoadL dst) shift)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9360
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9361
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9362
  format %{ "sarq    $dst, $shift" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9363
  opcode(0xC1, 0x7); /* C1 /7 ib */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9364
  ins_encode(REX_mem_wide(dst), OpcP,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9365
             RM_opc_mem(secondary, dst), Con8or32(shift));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9366
  ins_pipe(ialu_mem_imm);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9367
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9368
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9369
// Arithmetic Shift Right by variable
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9370
instruct sarL_rReg_CL(rRegL dst, rcx_RegI shift, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9371
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9372
  match(Set dst (RShiftL dst shift));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9373
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9374
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9375
  format %{ "sarq    $dst, $shift" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9376
  opcode(0xD3, 0x7); /* D3 /7 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9377
  ins_encode(REX_reg_wide(dst), OpcP, reg_opc(dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9378
  ins_pipe(ialu_reg_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9379
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9380
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9381
// Arithmetic Shift Right by variable
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9382
instruct sarL_mem_CL(memory dst, rcx_RegI shift, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9383
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9384
  match(Set dst (StoreL dst (RShiftL (LoadL dst) shift)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9385
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9386
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9387
  format %{ "sarq    $dst, $shift" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9388
  opcode(0xD3, 0x7); /* D3 /7 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9389
  ins_encode(REX_mem_wide(dst), OpcP, RM_opc_mem(secondary, dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9390
  ins_pipe(ialu_mem_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9391
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9392
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9393
// Logical shift right by one
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9394
instruct shrL_rReg_1(rRegL dst, immI1 shift, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9395
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9396
  match(Set dst (URShiftL dst shift));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9397
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9398
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9399
  format %{ "shrq    $dst, $shift" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9400
  opcode(0xD1, 0x5); /* D1 /5 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9401
  ins_encode(REX_reg_wide(dst), OpcP, reg_opc(dst ));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9402
  ins_pipe(ialu_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9403
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9404
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9405
// Logical shift right by one
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9406
instruct shrL_mem_1(memory dst, immI1 shift, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9407
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9408
  match(Set dst (StoreL dst (URShiftL (LoadL dst) shift)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9409
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9410
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9411
  format %{ "shrq    $dst, $shift" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9412
  opcode(0xD1, 0x5); /* D1 /5 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9413
  ins_encode(REX_mem_wide(dst), OpcP, RM_opc_mem(secondary, dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9414
  ins_pipe(ialu_mem_imm);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9415
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9416
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9417
// Logical Shift Right by 8-bit immediate
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9418
instruct shrL_rReg_imm(rRegL dst, immI8 shift, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9419
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9420
  match(Set dst (URShiftL dst shift));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9421
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9422
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9423
  format %{ "shrq    $dst, $shift" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9424
  opcode(0xC1, 0x5); /* C1 /5 ib */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9425
  ins_encode(reg_opc_imm_wide(dst, shift));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9426
  ins_pipe(ialu_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9427
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9428
1500
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
  9429
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9430
// Logical Shift Right by 8-bit immediate
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9431
instruct shrL_mem_imm(memory dst, immI8 shift, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9432
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9433
  match(Set dst (StoreL dst (URShiftL (LoadL dst) shift)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9434
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9435
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9436
  format %{ "shrq    $dst, $shift" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9437
  opcode(0xC1, 0x5); /* C1 /5 ib */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9438
  ins_encode(REX_mem_wide(dst), OpcP,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9439
             RM_opc_mem(secondary, dst), Con8or32(shift));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9440
  ins_pipe(ialu_mem_imm);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9441
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9442
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9443
// Logical Shift Right by variable
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9444
instruct shrL_rReg_CL(rRegL dst, rcx_RegI shift, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9445
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9446
  match(Set dst (URShiftL dst shift));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9447
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9448
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9449
  format %{ "shrq    $dst, $shift" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9450
  opcode(0xD3, 0x5); /* D3 /5 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9451
  ins_encode(REX_reg_wide(dst), OpcP, reg_opc(dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9452
  ins_pipe(ialu_reg_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9453
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9454
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9455
// Logical Shift Right by variable
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9456
instruct shrL_mem_CL(memory dst, rcx_RegI shift, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9457
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9458
  match(Set dst (StoreL dst (URShiftL (LoadL dst) shift)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9459
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9460
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9461
  format %{ "shrq    $dst, $shift" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9462
  opcode(0xD3, 0x5); /* D3 /5 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9463
  ins_encode(REX_mem_wide(dst), OpcP, RM_opc_mem(secondary, dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9464
  ins_pipe(ialu_mem_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9465
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9466
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9467
// Logical Shift Right by 24, followed by Arithmetic Shift Left by 24.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9468
// This idiom is used by the compiler for the i2b bytecode.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9469
instruct i2b(rRegI dst, rRegI src, immI_24 twentyfour)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9470
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9471
  match(Set dst (RShiftI (LShiftI src twentyfour) twentyfour));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9472
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9473
  format %{ "movsbl  $dst, $src\t# i2b" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9474
  opcode(0x0F, 0xBE);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9475
  ins_encode(REX_reg_breg(dst, src), OpcP, OpcS, reg_reg(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9476
  ins_pipe(ialu_reg_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9477
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9478
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9479
// Logical Shift Right by 16, followed by Arithmetic Shift Left by 16.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9480
// This idiom is used by the compiler the i2s bytecode.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9481
instruct i2s(rRegI dst, rRegI src, immI_16 sixteen)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9482
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9483
  match(Set dst (RShiftI (LShiftI src sixteen) sixteen));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9484
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9485
  format %{ "movswl  $dst, $src\t# i2s" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9486
  opcode(0x0F, 0xBF);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9487
  ins_encode(REX_reg_reg(dst, src), OpcP, OpcS, reg_reg(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9488
  ins_pipe(ialu_reg_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9489
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9490
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9491
// ROL/ROR instructions
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9492
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9493
// ROL expand
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9494
instruct rolI_rReg_imm1(rRegI dst, rFlagsReg cr) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9495
  effect(KILL cr, USE_DEF dst);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9496
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9497
  format %{ "roll    $dst" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9498
  opcode(0xD1, 0x0); /* Opcode  D1 /0 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9499
  ins_encode(REX_reg(dst), OpcP, reg_opc(dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9500
  ins_pipe(ialu_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9501
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9502
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9503
instruct rolI_rReg_imm8(rRegI dst, immI8 shift, rFlagsReg cr) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9504
  effect(USE_DEF dst, USE shift, KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9505
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9506
  format %{ "roll    $dst, $shift" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9507
  opcode(0xC1, 0x0); /* Opcode C1 /0 ib */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9508
  ins_encode( reg_opc_imm(dst, shift) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9509
  ins_pipe(ialu_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9510
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9511
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9512
instruct rolI_rReg_CL(no_rcx_RegI dst, rcx_RegI shift, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9513
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9514
  effect(USE_DEF dst, USE shift, KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9515
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9516
  format %{ "roll    $dst, $shift" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9517
  opcode(0xD3, 0x0); /* Opcode D3 /0 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9518
  ins_encode(REX_reg(dst), OpcP, reg_opc(dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9519
  ins_pipe(ialu_reg_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9520
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9521
// end of ROL expand
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9522
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9523
// Rotate Left by one
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9524
instruct rolI_rReg_i1(rRegI dst, immI1 lshift, immI_M1 rshift, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9525
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9526
  match(Set dst (OrI (LShiftI dst lshift) (URShiftI dst rshift)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9527
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9528
  expand %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9529
    rolI_rReg_imm1(dst, cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9530
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9531
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9532
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9533
// Rotate Left by 8-bit immediate
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9534
instruct rolI_rReg_i8(rRegI dst, immI8 lshift, immI8 rshift, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9535
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9536
  predicate(0 == ((n->in(1)->in(2)->get_int() + n->in(2)->in(2)->get_int()) & 0x1f));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9537
  match(Set dst (OrI (LShiftI dst lshift) (URShiftI dst rshift)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9538
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9539
  expand %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9540
    rolI_rReg_imm8(dst, lshift, cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9541
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9542
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9543
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9544
// Rotate Left by variable
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9545
instruct rolI_rReg_Var_C0(no_rcx_RegI dst, rcx_RegI shift, immI0 zero, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9546
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9547
  match(Set dst (OrI (LShiftI dst shift) (URShiftI dst (SubI zero shift))));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9548
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9549
  expand %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9550
    rolI_rReg_CL(dst, shift, cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9551
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9552
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9553
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9554
// Rotate Left by variable
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9555
instruct rolI_rReg_Var_C32(no_rcx_RegI dst, rcx_RegI shift, immI_32 c32, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9556
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9557
  match(Set dst (OrI (LShiftI dst shift) (URShiftI dst (SubI c32 shift))));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9558
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9559
  expand %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9560
    rolI_rReg_CL(dst, shift, cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9561
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9562
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9563
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9564
// ROR expand
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9565
instruct rorI_rReg_imm1(rRegI dst, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9566
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9567
  effect(USE_DEF dst, KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9568
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9569
  format %{ "rorl    $dst" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9570
  opcode(0xD1, 0x1); /* D1 /1 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9571
  ins_encode(REX_reg(dst), OpcP, reg_opc(dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9572
  ins_pipe(ialu_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9573
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9574
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9575
instruct rorI_rReg_imm8(rRegI dst, immI8 shift, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9576
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9577
  effect(USE_DEF dst, USE shift, KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9578
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9579
  format %{ "rorl    $dst, $shift" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9580
  opcode(0xC1, 0x1); /* C1 /1 ib */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9581
  ins_encode(reg_opc_imm(dst, shift));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9582
  ins_pipe(ialu_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9583
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9584
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9585
instruct rorI_rReg_CL(no_rcx_RegI dst, rcx_RegI shift, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9586
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9587
  effect(USE_DEF dst, USE shift, KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9588
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9589
  format %{ "rorl    $dst, $shift" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9590
  opcode(0xD3, 0x1); /* D3 /1 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9591
  ins_encode(REX_reg(dst), OpcP, reg_opc(dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9592
  ins_pipe(ialu_reg_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9593
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9594
// end of ROR expand
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9595
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9596
// Rotate Right by one
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9597
instruct rorI_rReg_i1(rRegI dst, immI1 rshift, immI_M1 lshift, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9598
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9599
  match(Set dst (OrI (URShiftI dst rshift) (LShiftI dst lshift)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9600
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9601
  expand %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9602
    rorI_rReg_imm1(dst, cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9603
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9604
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9605
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9606
// Rotate Right by 8-bit immediate
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9607
instruct rorI_rReg_i8(rRegI dst, immI8 rshift, immI8 lshift, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9608
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9609
  predicate(0 == ((n->in(1)->in(2)->get_int() + n->in(2)->in(2)->get_int()) & 0x1f));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9610
  match(Set dst (OrI (URShiftI dst rshift) (LShiftI dst lshift)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9611
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9612
  expand %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9613
    rorI_rReg_imm8(dst, rshift, cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9614
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9615
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9616
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9617
// Rotate Right by variable
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9618
instruct rorI_rReg_Var_C0(no_rcx_RegI dst, rcx_RegI shift, immI0 zero, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9619
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9620
  match(Set dst (OrI (URShiftI dst shift) (LShiftI dst (SubI zero shift))));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9621
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9622
  expand %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9623
    rorI_rReg_CL(dst, shift, cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9624
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9625
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9626
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9627
// Rotate Right by variable
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9628
instruct rorI_rReg_Var_C32(no_rcx_RegI dst, rcx_RegI shift, immI_32 c32, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9629
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9630
  match(Set dst (OrI (URShiftI dst shift) (LShiftI dst (SubI c32 shift))));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9631
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9632
  expand %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9633
    rorI_rReg_CL(dst, shift, cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9634
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9635
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9636
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9637
// for long rotate
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9638
// ROL expand
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9639
instruct rolL_rReg_imm1(rRegL dst, rFlagsReg cr) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9640
  effect(USE_DEF dst, KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9641
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9642
  format %{ "rolq    $dst" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9643
  opcode(0xD1, 0x0); /* Opcode  D1 /0 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9644
  ins_encode(REX_reg_wide(dst), OpcP, reg_opc(dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9645
  ins_pipe(ialu_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9646
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9647
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9648
instruct rolL_rReg_imm8(rRegL dst, immI8 shift, rFlagsReg cr) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9649
  effect(USE_DEF dst, USE shift, KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9650
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9651
  format %{ "rolq    $dst, $shift" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9652
  opcode(0xC1, 0x0); /* Opcode C1 /0 ib */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9653
  ins_encode( reg_opc_imm_wide(dst, shift) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9654
  ins_pipe(ialu_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9655
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9656
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9657
instruct rolL_rReg_CL(no_rcx_RegL dst, rcx_RegI shift, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9658
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9659
  effect(USE_DEF dst, USE shift, KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9660
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9661
  format %{ "rolq    $dst, $shift" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9662
  opcode(0xD3, 0x0); /* Opcode D3 /0 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9663
  ins_encode(REX_reg_wide(dst), OpcP, reg_opc(dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9664
  ins_pipe(ialu_reg_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9665
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9666
// end of ROL expand
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9667
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9668
// Rotate Left by one
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9669
instruct rolL_rReg_i1(rRegL dst, immI1 lshift, immI_M1 rshift, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9670
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9671
  match(Set dst (OrL (LShiftL dst lshift) (URShiftL dst rshift)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9672
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9673
  expand %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9674
    rolL_rReg_imm1(dst, cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9675
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9676
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9677
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9678
// Rotate Left by 8-bit immediate
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9679
instruct rolL_rReg_i8(rRegL dst, immI8 lshift, immI8 rshift, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9680
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9681
  predicate(0 == ((n->in(1)->in(2)->get_int() + n->in(2)->in(2)->get_int()) & 0x3f));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9682
  match(Set dst (OrL (LShiftL dst lshift) (URShiftL dst rshift)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9683
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9684
  expand %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9685
    rolL_rReg_imm8(dst, lshift, cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9686
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9687
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9688
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9689
// Rotate Left by variable
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9690
instruct rolL_rReg_Var_C0(no_rcx_RegL dst, rcx_RegI shift, immI0 zero, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9691
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9692
  match(Set dst (OrL (LShiftL dst shift) (URShiftL dst (SubI zero shift))));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9693
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9694
  expand %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9695
    rolL_rReg_CL(dst, shift, cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9696
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9697
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9698
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9699
// Rotate Left by variable
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9700
instruct rolL_rReg_Var_C64(no_rcx_RegL dst, rcx_RegI shift, immI_64 c64, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9701
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9702
  match(Set dst (OrL (LShiftL dst shift) (URShiftL dst (SubI c64 shift))));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9703
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9704
  expand %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9705
    rolL_rReg_CL(dst, shift, cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9706
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9707
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9708
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9709
// ROR expand
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9710
instruct rorL_rReg_imm1(rRegL dst, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9711
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9712
  effect(USE_DEF dst, KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9713
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9714
  format %{ "rorq    $dst" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9715
  opcode(0xD1, 0x1); /* D1 /1 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9716
  ins_encode(REX_reg_wide(dst), OpcP, reg_opc(dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9717
  ins_pipe(ialu_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9718
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9719
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9720
instruct rorL_rReg_imm8(rRegL dst, immI8 shift, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9721
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9722
  effect(USE_DEF dst, USE shift, KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9723
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9724
  format %{ "rorq    $dst, $shift" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9725
  opcode(0xC1, 0x1); /* C1 /1 ib */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9726
  ins_encode(reg_opc_imm_wide(dst, shift));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9727
  ins_pipe(ialu_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9728
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9729
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9730
instruct rorL_rReg_CL(no_rcx_RegL dst, rcx_RegI shift, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9731
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9732
  effect(USE_DEF dst, USE shift, KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9733
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9734
  format %{ "rorq    $dst, $shift" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9735
  opcode(0xD3, 0x1); /* D3 /1 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9736
  ins_encode(REX_reg_wide(dst), OpcP, reg_opc(dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9737
  ins_pipe(ialu_reg_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9738
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9739
// end of ROR expand
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9740
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9741
// Rotate Right by one
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9742
instruct rorL_rReg_i1(rRegL dst, immI1 rshift, immI_M1 lshift, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9743
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9744
  match(Set dst (OrL (URShiftL dst rshift) (LShiftL dst lshift)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9745
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9746
  expand %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9747
    rorL_rReg_imm1(dst, cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9748
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9749
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9750
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9751
// Rotate Right by 8-bit immediate
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9752
instruct rorL_rReg_i8(rRegL dst, immI8 rshift, immI8 lshift, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9753
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9754
  predicate(0 == ((n->in(1)->in(2)->get_int() + n->in(2)->in(2)->get_int()) & 0x3f));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9755
  match(Set dst (OrL (URShiftL dst rshift) (LShiftL dst lshift)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9756
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9757
  expand %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9758
    rorL_rReg_imm8(dst, rshift, cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9759
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9760
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9761
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9762
// Rotate Right by variable
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9763
instruct rorL_rReg_Var_C0(no_rcx_RegL dst, rcx_RegI shift, immI0 zero, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9764
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9765
  match(Set dst (OrL (URShiftL dst shift) (LShiftL dst (SubI zero shift))));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9766
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9767
  expand %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9768
    rorL_rReg_CL(dst, shift, cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9769
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9770
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9771
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9772
// Rotate Right by variable
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9773
instruct rorL_rReg_Var_C64(no_rcx_RegL dst, rcx_RegI shift, immI_64 c64, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9774
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9775
  match(Set dst (OrL (URShiftL dst shift) (LShiftL dst (SubI c64 shift))));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9776
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9777
  expand %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9778
    rorL_rReg_CL(dst, shift, cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9779
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9780
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9781
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9782
// Logical Instructions
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9783
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9784
// Integer Logical Instructions
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9785
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9786
// And Instructions
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9787
// And Register with Register
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9788
instruct andI_rReg(rRegI dst, rRegI src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9789
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9790
  match(Set dst (AndI dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9791
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9792
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9793
  format %{ "andl    $dst, $src\t# int" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9794
  opcode(0x23);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9795
  ins_encode(REX_reg_reg(dst, src), OpcP, reg_reg(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9796
  ins_pipe(ialu_reg_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9797
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9798
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9799
// And Register with Immediate 255
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9800
instruct andI_rReg_imm255(rRegI dst, immI_255 src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9801
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9802
  match(Set dst (AndI dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9803
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9804
  format %{ "movzbl  $dst, $dst\t# int & 0xFF" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9805
  opcode(0x0F, 0xB6);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9806
  ins_encode(REX_reg_breg(dst, dst), OpcP, OpcS, reg_reg(dst, dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9807
  ins_pipe(ialu_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9808
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9809
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9810
// And Register with Immediate 255 and promote to long
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9811
instruct andI2L_rReg_imm255(rRegL dst, rRegI src, immI_255 mask)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9812
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9813
  match(Set dst (ConvI2L (AndI src mask)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9814
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9815
  format %{ "movzbl  $dst, $src\t# int & 0xFF -> long" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9816
  opcode(0x0F, 0xB6);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9817
  ins_encode(REX_reg_breg(dst, src), OpcP, OpcS, reg_reg(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9818
  ins_pipe(ialu_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9819
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9820
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9821
// And Register with Immediate 65535
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9822
instruct andI_rReg_imm65535(rRegI dst, immI_65535 src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9823
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9824
  match(Set dst (AndI dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9825
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9826
  format %{ "movzwl  $dst, $dst\t# int & 0xFFFF" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9827
  opcode(0x0F, 0xB7);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9828
  ins_encode(REX_reg_reg(dst, dst), OpcP, OpcS, reg_reg(dst, dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9829
  ins_pipe(ialu_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9830
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9831
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9832
// And Register with Immediate 65535 and promote to long
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9833
instruct andI2L_rReg_imm65535(rRegL dst, rRegI src, immI_65535 mask)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9834
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9835
  match(Set dst (ConvI2L (AndI src mask)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9836
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9837
  format %{ "movzwl  $dst, $src\t# int & 0xFFFF -> long" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9838
  opcode(0x0F, 0xB7);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9839
  ins_encode(REX_reg_reg(dst, src), OpcP, OpcS, reg_reg(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9840
  ins_pipe(ialu_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9841
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9842
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9843
// And Register with Immediate
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9844
instruct andI_rReg_imm(rRegI dst, immI src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9845
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9846
  match(Set dst (AndI dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9847
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9848
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9849
  format %{ "andl    $dst, $src\t# int" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9850
  opcode(0x81, 0x04); /* Opcode 81 /4 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9851
  ins_encode(OpcSErm(dst, src), Con8or32(src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9852
  ins_pipe(ialu_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9853
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9854
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9855
// And Register with Memory
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9856
instruct andI_rReg_mem(rRegI dst, memory src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9857
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9858
  match(Set dst (AndI dst (LoadI src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9859
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9860
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9861
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9862
  format %{ "andl    $dst, $src\t# int" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9863
  opcode(0x23);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9864
  ins_encode(REX_reg_mem(dst, src), OpcP, reg_mem(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9865
  ins_pipe(ialu_reg_mem);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9866
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9867
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9868
// And Memory with Register
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9869
instruct andI_mem_rReg(memory dst, rRegI src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9870
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9871
  match(Set dst (StoreI dst (AndI (LoadI dst) src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9872
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9873
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9874
  ins_cost(150);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9875
  format %{ "andl    $dst, $src\t# int" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9876
  opcode(0x21); /* Opcode 21 /r */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9877
  ins_encode(REX_reg_mem(src, dst), OpcP, reg_mem(src, dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9878
  ins_pipe(ialu_mem_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9879
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9880
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9881
// And Memory with Immediate
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9882
instruct andI_mem_imm(memory dst, immI src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9883
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9884
  match(Set dst (StoreI dst (AndI (LoadI dst) src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9885
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9886
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9887
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9888
  format %{ "andl    $dst, $src\t# int" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9889
  opcode(0x81, 0x4); /* Opcode 81 /4 id */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9890
  ins_encode(REX_mem(dst), OpcSE(src),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9891
             RM_opc_mem(secondary, dst), Con8or32(src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9892
  ins_pipe(ialu_mem_imm);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9893
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9894
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9895
// Or Instructions
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9896
// Or Register with Register
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9897
instruct orI_rReg(rRegI dst, rRegI src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9898
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9899
  match(Set dst (OrI dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9900
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9901
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9902
  format %{ "orl     $dst, $src\t# int" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9903
  opcode(0x0B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9904
  ins_encode(REX_reg_reg(dst, src), OpcP, reg_reg(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9905
  ins_pipe(ialu_reg_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9906
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9907
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9908
// Or Register with Immediate
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9909
instruct orI_rReg_imm(rRegI dst, immI src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9910
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9911
  match(Set dst (OrI dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9912
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9913
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9914
  format %{ "orl     $dst, $src\t# int" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9915
  opcode(0x81, 0x01); /* Opcode 81 /1 id */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9916
  ins_encode(OpcSErm(dst, src), Con8or32(src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9917
  ins_pipe(ialu_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9918
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9919
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9920
// Or Register with Memory
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9921
instruct orI_rReg_mem(rRegI dst, memory src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9922
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9923
  match(Set dst (OrI dst (LoadI src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9924
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9925
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9926
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9927
  format %{ "orl     $dst, $src\t# int" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9928
  opcode(0x0B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9929
  ins_encode(REX_reg_mem(dst, src), OpcP, reg_mem(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9930
  ins_pipe(ialu_reg_mem);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9931
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9932
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9933
// Or Memory with Register
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9934
instruct orI_mem_rReg(memory dst, rRegI src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9935
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9936
  match(Set dst (StoreI dst (OrI (LoadI dst) src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9937
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9938
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9939
  ins_cost(150);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9940
  format %{ "orl     $dst, $src\t# int" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9941
  opcode(0x09); /* Opcode 09 /r */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9942
  ins_encode(REX_reg_mem(src, dst), OpcP, reg_mem(src, dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9943
  ins_pipe(ialu_mem_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9944
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9945
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9946
// Or Memory with Immediate
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9947
instruct orI_mem_imm(memory dst, immI src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9948
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9949
  match(Set dst (StoreI dst (OrI (LoadI dst) src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9950
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9951
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9952
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9953
  format %{ "orl     $dst, $src\t# int" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9954
  opcode(0x81, 0x1); /* Opcode 81 /1 id */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9955
  ins_encode(REX_mem(dst), OpcSE(src),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9956
             RM_opc_mem(secondary, dst), Con8or32(src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9957
  ins_pipe(ialu_mem_imm);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9958
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9959
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9960
// Xor Instructions
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9961
// Xor Register with Register
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9962
instruct xorI_rReg(rRegI dst, rRegI src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9963
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9964
  match(Set dst (XorI dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9965
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9966
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9967
  format %{ "xorl    $dst, $src\t# int" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9968
  opcode(0x33);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9969
  ins_encode(REX_reg_reg(dst, src), OpcP, reg_reg(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9970
  ins_pipe(ialu_reg_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9971
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9972
1435
72a8da703ff0 6752257: Use NOT instead of XOR -1 on x86
rasbold
parents: 1066
diff changeset
  9973
// Xor Register with Immediate -1
72a8da703ff0 6752257: Use NOT instead of XOR -1 on x86
rasbold
parents: 1066
diff changeset
  9974
instruct xorI_rReg_im1(rRegI dst, immI_M1 imm) %{
72a8da703ff0 6752257: Use NOT instead of XOR -1 on x86
rasbold
parents: 1066
diff changeset
  9975
  match(Set dst (XorI dst imm));  
72a8da703ff0 6752257: Use NOT instead of XOR -1 on x86
rasbold
parents: 1066
diff changeset
  9976
72a8da703ff0 6752257: Use NOT instead of XOR -1 on x86
rasbold
parents: 1066
diff changeset
  9977
  format %{ "not    $dst" %}  
72a8da703ff0 6752257: Use NOT instead of XOR -1 on x86
rasbold
parents: 1066
diff changeset
  9978
  ins_encode %{
72a8da703ff0 6752257: Use NOT instead of XOR -1 on x86
rasbold
parents: 1066
diff changeset
  9979
     __ notl($dst$$Register);
72a8da703ff0 6752257: Use NOT instead of XOR -1 on x86
rasbold
parents: 1066
diff changeset
  9980
  %}
72a8da703ff0 6752257: Use NOT instead of XOR -1 on x86
rasbold
parents: 1066
diff changeset
  9981
  ins_pipe(ialu_reg);
72a8da703ff0 6752257: Use NOT instead of XOR -1 on x86
rasbold
parents: 1066
diff changeset
  9982
%}
72a8da703ff0 6752257: Use NOT instead of XOR -1 on x86
rasbold
parents: 1066
diff changeset
  9983
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9984
// Xor Register with Immediate
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9985
instruct xorI_rReg_imm(rRegI dst, immI src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9986
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9987
  match(Set dst (XorI dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9988
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9989
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9990
  format %{ "xorl    $dst, $src\t# int" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9991
  opcode(0x81, 0x06); /* Opcode 81 /6 id */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9992
  ins_encode(OpcSErm(dst, src), Con8or32(src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9993
  ins_pipe(ialu_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9994
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9995
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9996
// Xor Register with Memory
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9997
instruct xorI_rReg_mem(rRegI dst, memory src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9998
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  9999
  match(Set dst (XorI dst (LoadI src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10000
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10001
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10002
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10003
  format %{ "xorl    $dst, $src\t# int" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10004
  opcode(0x33);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10005
  ins_encode(REX_reg_mem(dst, src), OpcP, reg_mem(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10006
  ins_pipe(ialu_reg_mem);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10007
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10008
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10009
// Xor Memory with Register
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10010
instruct xorI_mem_rReg(memory dst, rRegI src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10011
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10012
  match(Set dst (StoreI dst (XorI (LoadI dst) src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10013
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10014
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10015
  ins_cost(150);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10016
  format %{ "xorl    $dst, $src\t# int" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10017
  opcode(0x31); /* Opcode 31 /r */
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10018
  ins_encode(REX_reg_mem(src, dst), OpcP, reg_mem(src, dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10019
  ins_pipe(ialu_mem_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10020
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10021
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10022
// Xor Memory with Immediate
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10023
instruct xorI_mem_imm(memory dst, immI src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10024
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10025
  match(Set dst (StoreI dst (XorI (LoadI dst) src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10026
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10027
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10028
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10029
  format %{ "xorl    $dst, $src\t# int" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10030
  opcode(0x81, 0x6); /* Opcode 81 /6 id */
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10031
  ins_encode(REX_mem(dst), OpcSE(src),
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10032
             RM_opc_mem(secondary, dst), Con8or32(src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10033
  ins_pipe(ialu_mem_imm);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10034
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10035
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10036
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10037
// Long Logical Instructions
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10038
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10039
// And Instructions
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10040
// And Register with Register
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10041
instruct andL_rReg(rRegL dst, rRegL src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10042
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10043
  match(Set dst (AndL dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10044
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10045
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10046
  format %{ "andq    $dst, $src\t# long" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10047
  opcode(0x23);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10048
  ins_encode(REX_reg_reg_wide(dst, src), OpcP, reg_reg(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10049
  ins_pipe(ialu_reg_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10050
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10051
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10052
// And Register with Immediate 255
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10053
instruct andL_rReg_imm255(rRegL dst, immL_255 src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10054
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10055
  match(Set dst (AndL dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10056
2033
5bce9ca56d29 6805950: Typos in andL_rReg_imm instructions in x86_64.ad
twisti
parents: 2022
diff changeset
 10057
  format %{ "movzbq  $dst, $dst\t# long & 0xFF" %}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10058
  opcode(0x0F, 0xB6);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10059
  ins_encode(REX_reg_reg_wide(dst, dst), OpcP, OpcS, reg_reg(dst, dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10060
  ins_pipe(ialu_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10061
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10062
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10063
// And Register with Immediate 65535
2033
5bce9ca56d29 6805950: Typos in andL_rReg_imm instructions in x86_64.ad
twisti
parents: 2022
diff changeset
 10064
instruct andL_rReg_imm65535(rRegL dst, immL_65535 src)
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10065
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10066
  match(Set dst (AndL dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10067
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10068
  format %{ "movzwq  $dst, $dst\t# long & 0xFFFF" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10069
  opcode(0x0F, 0xB7);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10070
  ins_encode(REX_reg_reg_wide(dst, dst), OpcP, OpcS, reg_reg(dst, dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10071
  ins_pipe(ialu_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10072
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10073
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10074
// And Register with Immediate
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10075
instruct andL_rReg_imm(rRegL dst, immL32 src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10076
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10077
  match(Set dst (AndL dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10078
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10079
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10080
  format %{ "andq    $dst, $src\t# long" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10081
  opcode(0x81, 0x04); /* Opcode 81 /4 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10082
  ins_encode(OpcSErm_wide(dst, src), Con8or32(src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10083
  ins_pipe(ialu_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10084
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10085
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10086
// And Register with Memory
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10087
instruct andL_rReg_mem(rRegL dst, memory src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10088
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10089
  match(Set dst (AndL dst (LoadL src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10090
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10091
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10092
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10093
  format %{ "andq    $dst, $src\t# long" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10094
  opcode(0x23);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10095
  ins_encode(REX_reg_mem_wide(dst, src), OpcP, reg_mem(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10096
  ins_pipe(ialu_reg_mem);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10097
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10098
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10099
// And Memory with Register
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10100
instruct andL_mem_rReg(memory dst, rRegL src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10101
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10102
  match(Set dst (StoreL dst (AndL (LoadL dst) src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10103
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10104
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10105
  ins_cost(150);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10106
  format %{ "andq    $dst, $src\t# long" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10107
  opcode(0x21); /* Opcode 21 /r */
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10108
  ins_encode(REX_reg_mem_wide(src, dst), OpcP, reg_mem(src, dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10109
  ins_pipe(ialu_mem_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10110
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10111
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10112
// And Memory with Immediate
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10113
instruct andL_mem_imm(memory dst, immL32 src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10114
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10115
  match(Set dst (StoreL dst (AndL (LoadL dst) src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10116
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10117
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10118
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10119
  format %{ "andq    $dst, $src\t# long" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10120
  opcode(0x81, 0x4); /* Opcode 81 /4 id */
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10121
  ins_encode(REX_mem_wide(dst), OpcSE(src),
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10122
             RM_opc_mem(secondary, dst), Con8or32(src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10123
  ins_pipe(ialu_mem_imm);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10124
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10125
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10126
// Or Instructions
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10127
// Or Register with Register
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10128
instruct orL_rReg(rRegL dst, rRegL src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10129
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10130
  match(Set dst (OrL dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10131
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10132
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10133
  format %{ "orq     $dst, $src\t# long" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10134
  opcode(0x0B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10135
  ins_encode(REX_reg_reg_wide(dst, src), OpcP, reg_reg(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10136
  ins_pipe(ialu_reg_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10137
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10138
1500
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
 10139
// Use any_RegP to match R15 (TLS register) without spilling.
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
 10140
instruct orL_rReg_castP2X(rRegL dst, any_RegP src, rFlagsReg cr) %{
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
 10141
  match(Set dst (OrL dst (CastP2X src)));
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
 10142
  effect(KILL cr);
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
 10143
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
 10144
  format %{ "orq     $dst, $src\t# long" %}
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
 10145
  opcode(0x0B);
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
 10146
  ins_encode(REX_reg_reg_wide(dst, src), OpcP, reg_reg(dst, src));
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
 10147
  ins_pipe(ialu_reg_reg);
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
 10148
%}
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
 10149
bea9a90f3e8f 6462850: generate biased locking code in C2 ideal graph
kvn
parents: 1495
diff changeset
 10150
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10151
// Or Register with Immediate
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10152
instruct orL_rReg_imm(rRegL dst, immL32 src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10153
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10154
  match(Set dst (OrL dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10155
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10156
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10157
  format %{ "orq     $dst, $src\t# long" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10158
  opcode(0x81, 0x01); /* Opcode 81 /1 id */
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10159
  ins_encode(OpcSErm_wide(dst, src), Con8or32(src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10160
  ins_pipe(ialu_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10161
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10162
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10163
// Or Register with Memory
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10164
instruct orL_rReg_mem(rRegL dst, memory src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10165
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10166
  match(Set dst (OrL dst (LoadL src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10167
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10168
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10169
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10170
  format %{ "orq     $dst, $src\t# long" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10171
  opcode(0x0B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10172
  ins_encode(REX_reg_mem_wide(dst, src), OpcP, reg_mem(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10173
  ins_pipe(ialu_reg_mem);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10174
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10175
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10176
// Or Memory with Register
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10177
instruct orL_mem_rReg(memory dst, rRegL src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10178
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10179
  match(Set dst (StoreL dst (OrL (LoadL dst) src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10180
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10181
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10182
  ins_cost(150);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10183
  format %{ "orq     $dst, $src\t# long" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10184
  opcode(0x09); /* Opcode 09 /r */
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10185
  ins_encode(REX_reg_mem_wide(src, dst), OpcP, reg_mem(src, dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10186
  ins_pipe(ialu_mem_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10187
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10188
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10189
// Or Memory with Immediate
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10190
instruct orL_mem_imm(memory dst, immL32 src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10191
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10192
  match(Set dst (StoreL dst (OrL (LoadL dst) src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10193
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10194
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10195
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10196
  format %{ "orq     $dst, $src\t# long" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10197
  opcode(0x81, 0x1); /* Opcode 81 /1 id */
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10198
  ins_encode(REX_mem_wide(dst), OpcSE(src),
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10199
             RM_opc_mem(secondary, dst), Con8or32(src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10200
  ins_pipe(ialu_mem_imm);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10201
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10202
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10203
// Xor Instructions
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10204
// Xor Register with Register
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10205
instruct xorL_rReg(rRegL dst, rRegL src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10206
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10207
  match(Set dst (XorL dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10208
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10209
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10210
  format %{ "xorq    $dst, $src\t# long" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10211
  opcode(0x33);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10212
  ins_encode(REX_reg_reg_wide(dst, src), OpcP, reg_reg(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10213
  ins_pipe(ialu_reg_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10214
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10215
1435
72a8da703ff0 6752257: Use NOT instead of XOR -1 on x86
rasbold
parents: 1066
diff changeset
 10216
// Xor Register with Immediate -1
72a8da703ff0 6752257: Use NOT instead of XOR -1 on x86
rasbold
parents: 1066
diff changeset
 10217
instruct xorL_rReg_im1(rRegL dst, immL_M1 imm) %{
72a8da703ff0 6752257: Use NOT instead of XOR -1 on x86
rasbold
parents: 1066
diff changeset
 10218
  match(Set dst (XorL dst imm));  
72a8da703ff0 6752257: Use NOT instead of XOR -1 on x86
rasbold
parents: 1066
diff changeset
 10219
72a8da703ff0 6752257: Use NOT instead of XOR -1 on x86
rasbold
parents: 1066
diff changeset
 10220
  format %{ "notq   $dst" %}  
72a8da703ff0 6752257: Use NOT instead of XOR -1 on x86
rasbold
parents: 1066
diff changeset
 10221
  ins_encode %{
72a8da703ff0 6752257: Use NOT instead of XOR -1 on x86
rasbold
parents: 1066
diff changeset
 10222
     __ notq($dst$$Register);
72a8da703ff0 6752257: Use NOT instead of XOR -1 on x86
rasbold
parents: 1066
diff changeset
 10223
  %}
72a8da703ff0 6752257: Use NOT instead of XOR -1 on x86
rasbold
parents: 1066
diff changeset
 10224
  ins_pipe(ialu_reg);
72a8da703ff0 6752257: Use NOT instead of XOR -1 on x86
rasbold
parents: 1066
diff changeset
 10225
%}
72a8da703ff0 6752257: Use NOT instead of XOR -1 on x86
rasbold
parents: 1066
diff changeset
 10226
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10227
// Xor Register with Immediate
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10228
instruct xorL_rReg_imm(rRegL dst, immL32 src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10229
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10230
  match(Set dst (XorL dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10231
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10232
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10233
  format %{ "xorq    $dst, $src\t# long" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10234
  opcode(0x81, 0x06); /* Opcode 81 /6 id */
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10235
  ins_encode(OpcSErm_wide(dst, src), Con8or32(src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10236
  ins_pipe(ialu_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10237
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10238
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10239
// Xor Register with Memory
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10240
instruct xorL_rReg_mem(rRegL dst, memory src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10241
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10242
  match(Set dst (XorL dst (LoadL src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10243
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10244
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10245
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10246
  format %{ "xorq    $dst, $src\t# long" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10247
  opcode(0x33);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10248
  ins_encode(REX_reg_mem_wide(dst, src), OpcP, reg_mem(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10249
  ins_pipe(ialu_reg_mem);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10250
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10251
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10252
// Xor Memory with Register
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10253
instruct xorL_mem_rReg(memory dst, rRegL src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10254
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10255
  match(Set dst (StoreL dst (XorL (LoadL dst) src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10256
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10257
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10258
  ins_cost(150);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10259
  format %{ "xorq    $dst, $src\t# long" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10260
  opcode(0x31); /* Opcode 31 /r */
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10261
  ins_encode(REX_reg_mem_wide(src, dst), OpcP, reg_mem(src, dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10262
  ins_pipe(ialu_mem_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10263
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10264
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10265
// Xor Memory with Immediate
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10266
instruct xorL_mem_imm(memory dst, immL32 src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10267
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10268
  match(Set dst (StoreL dst (XorL (LoadL dst) src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10269
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10270
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10271
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10272
  format %{ "xorq    $dst, $src\t# long" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10273
  opcode(0x81, 0x6); /* Opcode 81 /6 id */
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10274
  ins_encode(REX_mem_wide(dst), OpcSE(src),
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10275
             RM_opc_mem(secondary, dst), Con8or32(src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10276
  ins_pipe(ialu_mem_imm);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10277
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10278
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10279
// Convert Int to Boolean
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10280
instruct convI2B(rRegI dst, rRegI src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10281
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10282
  match(Set dst (Conv2B src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10283
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10284
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10285
  format %{ "testl   $src, $src\t# ci2b\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10286
            "setnz   $dst\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10287
            "movzbl  $dst, $dst" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10288
  ins_encode(REX_reg_reg(src, src), opc_reg_reg(0x85, src, src), // testl
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10289
             setNZ_reg(dst),
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10290
             REX_reg_breg(dst, dst), // movzbl
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10291
             Opcode(0x0F), Opcode(0xB6), reg_reg(dst, dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10292
  ins_pipe(pipe_slow); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10293
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10294
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10295
// Convert Pointer to Boolean
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10296
instruct convP2B(rRegI dst, rRegP src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10297
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10298
  match(Set dst (Conv2B src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10299
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10300
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10301
  format %{ "testq   $src, $src\t# cp2b\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10302
            "setnz   $dst\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10303
            "movzbl  $dst, $dst" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10304
  ins_encode(REX_reg_reg_wide(src, src), opc_reg_reg(0x85, src, src), // testq
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10305
             setNZ_reg(dst),
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10306
             REX_reg_breg(dst, dst), // movzbl
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10307
             Opcode(0x0F), Opcode(0xB6), reg_reg(dst, dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10308
  ins_pipe(pipe_slow); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10309
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10310
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10311
instruct cmpLTMask(rRegI dst, rRegI p, rRegI q, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10312
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10313
  match(Set dst (CmpLTMask p q));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10314
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10315
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10316
  ins_cost(400); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10317
  format %{ "cmpl    $p, $q\t# cmpLTMask\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10318
            "setlt   $dst\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10319
            "movzbl  $dst, $dst\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10320
            "negl    $dst" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10321
  ins_encode(REX_reg_reg(p, q), opc_reg_reg(0x3B, p, q), // cmpl
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10322
             setLT_reg(dst),
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10323
             REX_reg_breg(dst, dst), // movzbl
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10324
             Opcode(0x0F), Opcode(0xB6), reg_reg(dst, dst),
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10325
             neg_reg(dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10326
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10327
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10328
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10329
instruct cmpLTMask0(rRegI dst, immI0 zero, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10330
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10331
  match(Set dst (CmpLTMask dst zero));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10332
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10333
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10334
  ins_cost(100); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10335
  format %{ "sarl    $dst, #31\t# cmpLTMask0" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10336
  opcode(0xC1, 0x7);  /* C1 /7 ib */
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10337
  ins_encode(reg_opc_imm(dst, 0x1F));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10338
  ins_pipe(ialu_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10339
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10340
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10341
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10342
instruct cadd_cmpLTMask(rRegI p, rRegI q, rRegI y,
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10343
                         rRegI tmp,
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10344
                         rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10345
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10346
  match(Set p (AddI (AndI (CmpLTMask p q) y) (SubI p q)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10347
  effect(TEMP tmp, KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10348
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10349
  ins_cost(400); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10350
  format %{ "subl    $p, $q\t# cadd_cmpLTMask1\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10351
            "sbbl    $tmp, $tmp\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10352
            "andl    $tmp, $y\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10353
            "addl    $p, $tmp" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10354
  ins_encode(enc_cmpLTP(p, q, y, tmp));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10355
  ins_pipe(pipe_cmplt);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10356
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10357
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10358
/* If I enable this, I encourage spilling in the inner loop of compress.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10359
instruct cadd_cmpLTMask_mem( rRegI p, rRegI q, memory y, rRegI tmp, rFlagsReg cr )
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10360
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10361
  match(Set p (AddI (AndI (CmpLTMask p q) (LoadI y)) (SubI p q)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10362
  effect( TEMP tmp, KILL cr );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10363
  ins_cost(400);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10364
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10365
  format %{ "SUB    $p,$q\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10366
            "SBB    RCX,RCX\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10367
            "AND    RCX,$y\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10368
            "ADD    $p,RCX" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10369
  ins_encode( enc_cmpLTP_mem(p,q,y,tmp) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10370
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10371
*/
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10372
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10373
//---------- FP Instructions------------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10374
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10375
instruct cmpF_cc_reg(rFlagsRegU cr, regF src1, regF src2)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10376
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10377
  match(Set cr (CmpF src1 src2));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10378
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10379
  ins_cost(145);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10380
  format %{ "ucomiss $src1, $src2\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10381
            "jnp,s   exit\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10382
            "pushfq\t# saw NaN, set CF\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10383
            "andq    [rsp], #0xffffff2b\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10384
            "popfq\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10385
    "exit:   nop\t# avoid branch to branch" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10386
  opcode(0x0F, 0x2E);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10387
  ins_encode(REX_reg_reg(src1, src2), OpcP, OpcS, reg_reg(src1, src2),
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10388
             cmpfp_fixup);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10389
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10390
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10391
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 10392
instruct cmpF_cc_reg_CF(rFlagsRegUCF cr, regF src1, regF src2) %{
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 10393
  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
 10394
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 10395
  ins_cost(145);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 10396
  format %{ "ucomiss $src1, $src2" %}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 10397
  ins_encode %{
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 10398
    __ ucomiss($src1$$XMMRegister, $src2$$XMMRegister);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 10399
  %}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 10400
  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
 10401
%}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 10402
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10403
instruct cmpF_cc_mem(rFlagsRegU cr, regF src1, memory src2)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10404
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10405
  match(Set cr (CmpF src1 (LoadF src2)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10406
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10407
  ins_cost(145);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10408
  format %{ "ucomiss $src1, $src2\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10409
            "jnp,s   exit\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10410
            "pushfq\t# saw NaN, set CF\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10411
            "andq    [rsp], #0xffffff2b\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10412
            "popfq\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10413
    "exit:   nop\t# avoid branch to branch" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10414
  opcode(0x0F, 0x2E);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10415
  ins_encode(REX_reg_mem(src1, src2), OpcP, OpcS, reg_mem(src1, src2),
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10416
             cmpfp_fixup);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10417
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10418
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10419
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 10420
instruct cmpF_cc_memCF(rFlagsRegUCF cr, regF src1, memory src2) %{
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 10421
  match(Set cr (CmpF src1 (LoadF src2)));
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 10422
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 10423
  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
 10424
  format %{ "ucomiss $src1, $src2" %}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 10425
  opcode(0x0F, 0x2E);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 10426
  ins_encode(REX_reg_mem(src1, src2), OpcP, OpcS, reg_mem(src1, src2));
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 10427
  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
 10428
%}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 10429
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10430
instruct cmpF_cc_imm(rFlagsRegU cr, regF src1, immF src2)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10431
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10432
  match(Set cr (CmpF src1 src2));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10433
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10434
  ins_cost(145);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10435
  format %{ "ucomiss $src1, $src2\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10436
            "jnp,s   exit\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10437
            "pushfq\t# saw NaN, set CF\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10438
            "andq    [rsp], #0xffffff2b\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10439
            "popfq\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10440
    "exit:   nop\t# avoid branch to branch" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10441
  opcode(0x0F, 0x2E);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10442
  ins_encode(REX_reg_mem(src1, src2), OpcP, OpcS, load_immF(src1, src2),
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10443
             cmpfp_fixup);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10444
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10445
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10446
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 10447
instruct cmpF_cc_immCF(rFlagsRegUCF cr, regF src1, immF src2) %{
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 10448
  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
 10449
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 10450
  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
 10451
  format %{ "ucomiss $src1, $src2" %}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 10452
  opcode(0x0F, 0x2E);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 10453
  ins_encode(REX_reg_mem(src1, src2), OpcP, OpcS, load_immF(src1, src2));
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 10454
  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
 10455
%}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 10456
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10457
instruct cmpD_cc_reg(rFlagsRegU cr, regD src1, regD src2)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10458
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10459
  match(Set cr (CmpD src1 src2));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10460
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10461
  ins_cost(145);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10462
  format %{ "ucomisd $src1, $src2\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10463
            "jnp,s   exit\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10464
            "pushfq\t# saw NaN, set CF\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10465
            "andq    [rsp], #0xffffff2b\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10466
            "popfq\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10467
    "exit:   nop\t# avoid branch to branch" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10468
  opcode(0x66, 0x0F, 0x2E);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10469
  ins_encode(OpcP, REX_reg_reg(src1, src2), OpcS, OpcT, reg_reg(src1, src2),
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10470
             cmpfp_fixup);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10471
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10472
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10473
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 10474
instruct cmpD_cc_reg_CF(rFlagsRegUCF cr, regD src1, regD src2) %{
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 10475
  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
 10476
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 10477
  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
 10478
  format %{ "ucomisd $src1, $src2 test" %}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 10479
  ins_encode %{
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 10480
    __ ucomisd($src1$$XMMRegister, $src2$$XMMRegister);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 10481
  %}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 10482
  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
 10483
%}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 10484
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10485
instruct cmpD_cc_mem(rFlagsRegU cr, regD src1, memory src2)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10486
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10487
  match(Set cr (CmpD src1 (LoadD src2)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10488
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10489
  ins_cost(145);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10490
  format %{ "ucomisd $src1, $src2\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10491
            "jnp,s   exit\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10492
            "pushfq\t# saw NaN, set CF\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10493
            "andq    [rsp], #0xffffff2b\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10494
            "popfq\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10495
    "exit:   nop\t# avoid branch to branch" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10496
  opcode(0x66, 0x0F, 0x2E);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10497
  ins_encode(OpcP, REX_reg_mem(src1, src2), OpcS, OpcT, reg_mem(src1, src2),
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10498
             cmpfp_fixup);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10499
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10500
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10501
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 10502
instruct cmpD_cc_memCF(rFlagsRegUCF cr, regD src1, memory src2) %{
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 10503
  match(Set cr (CmpD src1 (LoadD src2)));
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 10504
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 10505
  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
 10506
  format %{ "ucomisd $src1, $src2" %}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 10507
  opcode(0x66, 0x0F, 0x2E);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 10508
  ins_encode(OpcP, REX_reg_mem(src1, src2), OpcS, OpcT, reg_mem(src1, src2));
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 10509
  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
 10510
%}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 10511
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10512
instruct cmpD_cc_imm(rFlagsRegU cr, regD src1, immD src2)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10513
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10514
  match(Set cr (CmpD src1 src2));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10515
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10516
  ins_cost(145);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10517
  format %{ "ucomisd $src1, [$src2]\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10518
            "jnp,s   exit\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10519
            "pushfq\t# saw NaN, set CF\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10520
            "andq    [rsp], #0xffffff2b\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10521
            "popfq\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10522
    "exit:   nop\t# avoid branch to branch" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10523
  opcode(0x66, 0x0F, 0x2E);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10524
  ins_encode(OpcP, REX_reg_mem(src1, src2), OpcS, OpcT, load_immD(src1, src2),
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10525
             cmpfp_fixup);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10526
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10527
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10528
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 10529
instruct cmpD_cc_immCF(rFlagsRegUCF cr, regD src1, immD src2) %{
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 10530
  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
 10531
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 10532
  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
 10533
  format %{ "ucomisd $src1, [$src2]" %}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 10534
  opcode(0x66, 0x0F, 0x2E);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 10535
  ins_encode(OpcP, REX_reg_mem(src1, src2), OpcS, OpcT, load_immD(src1, src2));
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 10536
  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
 10537
%}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 10538
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10539
// Compare into -1,0,1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10540
instruct cmpF_reg(rRegI dst, regF src1, regF src2, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10541
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10542
  match(Set dst (CmpF3 src1 src2));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10543
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10544
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10545
  ins_cost(275);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10546
  format %{ "ucomiss $src1, $src2\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10547
            "movl    $dst, #-1\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10548
            "jp,s    done\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10549
            "jb,s    done\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10550
            "setne   $dst\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10551
            "movzbl  $dst, $dst\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10552
    "done:" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10553
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10554
  opcode(0x0F, 0x2E);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10555
  ins_encode(REX_reg_reg(src1, src2), OpcP, OpcS, reg_reg(src1, src2),
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10556
             cmpfp3(dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10557
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10558
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10559
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10560
// Compare into -1,0,1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10561
instruct cmpF_mem(rRegI dst, regF src1, memory src2, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10562
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10563
  match(Set dst (CmpF3 src1 (LoadF src2)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10564
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10565
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10566
  ins_cost(275);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10567
  format %{ "ucomiss $src1, $src2\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10568
            "movl    $dst, #-1\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10569
            "jp,s    done\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10570
            "jb,s    done\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10571
            "setne   $dst\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10572
            "movzbl  $dst, $dst\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10573
    "done:" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10574
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10575
  opcode(0x0F, 0x2E);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10576
  ins_encode(REX_reg_mem(src1, src2), OpcP, OpcS, reg_mem(src1, src2),
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10577
             cmpfp3(dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10578
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10579
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10580
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10581
// Compare into -1,0,1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10582
instruct cmpF_imm(rRegI dst, regF src1, immF src2, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10583
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10584
  match(Set dst (CmpF3 src1 src2));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10585
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10586
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10587
  ins_cost(275);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10588
  format %{ "ucomiss $src1, [$src2]\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10589
            "movl    $dst, #-1\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10590
            "jp,s    done\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10591
            "jb,s    done\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10592
            "setne   $dst\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10593
            "movzbl  $dst, $dst\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10594
    "done:" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10595
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10596
  opcode(0x0F, 0x2E);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10597
  ins_encode(REX_reg_mem(src1, src2), OpcP, OpcS, load_immF(src1, src2),
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10598
             cmpfp3(dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10599
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10600
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10601
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10602
// Compare into -1,0,1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10603
instruct cmpD_reg(rRegI dst, regD src1, regD src2, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10604
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10605
  match(Set dst (CmpD3 src1 src2));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10606
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10607
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10608
  ins_cost(275);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10609
  format %{ "ucomisd $src1, $src2\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10610
            "movl    $dst, #-1\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10611
            "jp,s    done\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10612
            "jb,s    done\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10613
            "setne   $dst\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10614
            "movzbl  $dst, $dst\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10615
    "done:" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10616
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10617
  opcode(0x66, 0x0F, 0x2E);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10618
  ins_encode(OpcP, REX_reg_reg(src1, src2), OpcS, OpcT, reg_reg(src1, src2),
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10619
             cmpfp3(dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10620
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10621
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10622
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10623
// Compare into -1,0,1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10624
instruct cmpD_mem(rRegI dst, regD src1, memory src2, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10625
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10626
  match(Set dst (CmpD3 src1 (LoadD src2)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10627
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10628
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10629
  ins_cost(275);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10630
  format %{ "ucomisd $src1, $src2\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10631
            "movl    $dst, #-1\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10632
            "jp,s    done\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10633
            "jb,s    done\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10634
            "setne   $dst\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10635
            "movzbl  $dst, $dst\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10636
    "done:" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10637
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10638
  opcode(0x66, 0x0F, 0x2E);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10639
  ins_encode(OpcP, REX_reg_mem(src1, src2), OpcS, OpcT, reg_mem(src1, src2),
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10640
             cmpfp3(dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10641
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10642
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10643
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10644
// Compare into -1,0,1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10645
instruct cmpD_imm(rRegI dst, regD src1, immD src2, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10646
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10647
  match(Set dst (CmpD3 src1 src2));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10648
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10649
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10650
  ins_cost(275);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10651
  format %{ "ucomisd $src1, [$src2]\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10652
            "movl    $dst, #-1\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10653
            "jp,s    done\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10654
            "jb,s    done\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10655
            "setne   $dst\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10656
            "movzbl  $dst, $dst\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10657
    "done:" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10658
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10659
  opcode(0x66, 0x0F, 0x2E);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10660
  ins_encode(OpcP, REX_reg_mem(src1, src2), OpcS, OpcT, load_immD(src1, src2),
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10661
             cmpfp3(dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10662
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10663
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10664
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10665
instruct addF_reg(regF dst, regF src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10666
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10667
  match(Set dst (AddF dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10668
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10669
  format %{ "addss   $dst, $src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10670
  ins_cost(150); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10671
  opcode(0xF3, 0x0F, 0x58);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10672
  ins_encode(OpcP, REX_reg_reg(dst, src), OpcS, OpcT, reg_reg(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10673
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10674
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10675
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10676
instruct addF_mem(regF dst, memory src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10677
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10678
  match(Set dst (AddF dst (LoadF src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10679
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10680
  format %{ "addss   $dst, $src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10681
  ins_cost(150); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10682
  opcode(0xF3, 0x0F, 0x58);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10683
  ins_encode(OpcP, REX_reg_mem(dst, src), OpcS, OpcT, reg_mem(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10684
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10685
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10686
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10687
instruct addF_imm(regF dst, immF src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10688
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10689
  match(Set dst (AddF dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10690
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10691
  format %{ "addss   $dst, [$src]" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10692
  ins_cost(150); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10693
  opcode(0xF3, 0x0F, 0x58);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10694
  ins_encode(OpcP, REX_reg_mem(dst, src), OpcS, OpcT, load_immF(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10695
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10696
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10697
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10698
instruct addD_reg(regD dst, regD src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10699
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10700
  match(Set dst (AddD dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10701
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10702
  format %{ "addsd   $dst, $src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10703
  ins_cost(150); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10704
  opcode(0xF2, 0x0F, 0x58);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10705
  ins_encode(OpcP, REX_reg_reg(dst, src), OpcS, OpcT, reg_reg(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10706
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10707
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10708
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10709
instruct addD_mem(regD dst, memory src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10710
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10711
  match(Set dst (AddD dst (LoadD src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10712
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10713
  format %{ "addsd   $dst, $src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10714
  ins_cost(150); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10715
  opcode(0xF2, 0x0F, 0x58);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10716
  ins_encode(OpcP, REX_reg_mem(dst, src), OpcS, OpcT, reg_mem(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10717
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10718
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10719
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10720
instruct addD_imm(regD dst, immD src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10721
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10722
  match(Set dst (AddD dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10723
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10724
  format %{ "addsd   $dst, [$src]" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10725
  ins_cost(150); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10726
  opcode(0xF2, 0x0F, 0x58);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10727
  ins_encode(OpcP, REX_reg_mem(dst, src), OpcS, OpcT, load_immD(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10728
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10729
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10730
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10731
instruct subF_reg(regF dst, regF src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10732
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10733
  match(Set dst (SubF dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10734
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10735
  format %{ "subss   $dst, $src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10736
  ins_cost(150); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10737
  opcode(0xF3, 0x0F, 0x5C);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10738
  ins_encode(OpcP, REX_reg_reg(dst, src), OpcS, OpcT, reg_reg(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10739
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10740
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10741
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10742
instruct subF_mem(regF dst, memory src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10743
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10744
  match(Set dst (SubF dst (LoadF src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10745
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10746
  format %{ "subss   $dst, $src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10747
  ins_cost(150); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10748
  opcode(0xF3, 0x0F, 0x5C);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10749
  ins_encode(OpcP, REX_reg_mem(dst, src), OpcS, OpcT, reg_mem(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10750
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10751
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10752
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10753
instruct subF_imm(regF dst, immF src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10754
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10755
  match(Set dst (SubF dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10756
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10757
  format %{ "subss   $dst, [$src]" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10758
  ins_cost(150); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10759
  opcode(0xF3, 0x0F, 0x5C);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10760
  ins_encode(OpcP, REX_reg_mem(dst, src), OpcS, OpcT, load_immF(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10761
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10762
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10763
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10764
instruct subD_reg(regD dst, regD src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10765
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10766
  match(Set dst (SubD dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10767
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10768
  format %{ "subsd   $dst, $src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10769
  ins_cost(150); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10770
  opcode(0xF2, 0x0F, 0x5C);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10771
  ins_encode(OpcP, REX_reg_reg(dst, src), OpcS, OpcT, reg_reg(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10772
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10773
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10774
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10775
instruct subD_mem(regD dst, memory src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10776
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10777
  match(Set dst (SubD dst (LoadD src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10778
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10779
  format %{ "subsd   $dst, $src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10780
  ins_cost(150); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10781
  opcode(0xF2, 0x0F, 0x5C);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10782
  ins_encode(OpcP, REX_reg_mem(dst, src), OpcS, OpcT, reg_mem(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10783
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10784
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10785
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10786
instruct subD_imm(regD dst, immD src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10787
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10788
  match(Set dst (SubD dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10789
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10790
  format %{ "subsd   $dst, [$src]" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10791
  ins_cost(150); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10792
  opcode(0xF2, 0x0F, 0x5C);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10793
  ins_encode(OpcP, REX_reg_mem(dst, src), OpcS, OpcT, load_immD(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10794
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10795
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10796
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10797
instruct mulF_reg(regF dst, regF src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10798
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10799
  match(Set dst (MulF dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10800
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10801
  format %{ "mulss   $dst, $src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10802
  ins_cost(150); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10803
  opcode(0xF3, 0x0F, 0x59);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10804
  ins_encode(OpcP, REX_reg_reg(dst, src), OpcS, OpcT, reg_reg(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10805
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10806
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10807
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10808
instruct mulF_mem(regF dst, memory src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10809
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10810
  match(Set dst (MulF dst (LoadF src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10811
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10812
  format %{ "mulss   $dst, $src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10813
  ins_cost(150); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10814
  opcode(0xF3, 0x0F, 0x59);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10815
  ins_encode(OpcP, REX_reg_mem(dst, src), OpcS, OpcT, reg_mem(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10816
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10817
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10818
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10819
instruct mulF_imm(regF dst, immF src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10820
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10821
  match(Set dst (MulF dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10822
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10823
  format %{ "mulss   $dst, [$src]" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10824
  ins_cost(150); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10825
  opcode(0xF3, 0x0F, 0x59);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10826
  ins_encode(OpcP, REX_reg_mem(dst, src), OpcS, OpcT, load_immF(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10827
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10828
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10829
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10830
instruct mulD_reg(regD dst, regD src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10831
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10832
  match(Set dst (MulD dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10833
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10834
  format %{ "mulsd   $dst, $src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10835
  ins_cost(150); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10836
  opcode(0xF2, 0x0F, 0x59);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10837
  ins_encode(OpcP, REX_reg_reg(dst, src), OpcS, OpcT, reg_reg(dst, src));
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
instruct mulD_mem(regD dst, memory src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10842
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10843
  match(Set dst (MulD dst (LoadD src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10844
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10845
  format %{ "mulsd   $dst, $src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10846
  ins_cost(150); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10847
  opcode(0xF2, 0x0F, 0x59);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10848
  ins_encode(OpcP, REX_reg_mem(dst, src), OpcS, OpcT, reg_mem(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10849
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10850
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10851
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10852
instruct mulD_imm(regD dst, immD src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10853
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10854
  match(Set dst (MulD dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10855
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10856
  format %{ "mulsd   $dst, [$src]" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10857
  ins_cost(150); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10858
  opcode(0xF2, 0x0F, 0x59);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10859
  ins_encode(OpcP, REX_reg_mem(dst, src), OpcS, OpcT, load_immD(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10860
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10861
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10862
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10863
instruct divF_reg(regF dst, regF src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10864
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10865
  match(Set dst (DivF dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10866
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10867
  format %{ "divss   $dst, $src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10868
  ins_cost(150); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10869
  opcode(0xF3, 0x0F, 0x5E);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10870
  ins_encode(OpcP, REX_reg_reg(dst, src), OpcS, OpcT, reg_reg(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10871
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10872
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10873
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10874
instruct divF_mem(regF dst, memory src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10875
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10876
  match(Set dst (DivF dst (LoadF src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10877
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10878
  format %{ "divss   $dst, $src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10879
  ins_cost(150); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10880
  opcode(0xF3, 0x0F, 0x5E);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10881
  ins_encode(OpcP, REX_reg_mem(dst, src), OpcS, OpcT, reg_mem(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10882
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10883
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10884
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10885
instruct divF_imm(regF dst, immF src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10886
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10887
  match(Set dst (DivF dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10888
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10889
  format %{ "divss   $dst, [$src]" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10890
  ins_cost(150); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10891
  opcode(0xF3, 0x0F, 0x5E);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10892
  ins_encode(OpcP, REX_reg_mem(dst, src), OpcS, OpcT, load_immF(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10893
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10894
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10895
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10896
instruct divD_reg(regD dst, regD src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10897
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10898
  match(Set dst (DivD dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10899
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10900
  format %{ "divsd   $dst, $src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10901
  ins_cost(150); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10902
  opcode(0xF2, 0x0F, 0x5E);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10903
  ins_encode(OpcP, REX_reg_reg(dst, src), OpcS, OpcT, reg_reg(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10904
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10905
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10906
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10907
instruct divD_mem(regD dst, memory src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10908
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10909
  match(Set dst (DivD dst (LoadD src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10910
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10911
  format %{ "divsd   $dst, $src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10912
  ins_cost(150); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10913
  opcode(0xF2, 0x0F, 0x5E);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10914
  ins_encode(OpcP, REX_reg_mem(dst, src), OpcS, OpcT, reg_mem(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10915
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10916
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10917
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10918
instruct divD_imm(regD dst, immD src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10919
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10920
  match(Set dst (DivD dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10921
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10922
  format %{ "divsd   $dst, [$src]" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10923
  ins_cost(150); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10924
  opcode(0xF2, 0x0F, 0x5E);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10925
  ins_encode(OpcP, REX_reg_mem(dst, src), OpcS, OpcT, load_immD(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10926
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10927
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10928
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10929
instruct sqrtF_reg(regF dst, regF src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10930
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10931
  match(Set dst (ConvD2F (SqrtD (ConvF2D src))));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10932
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10933
  format %{ "sqrtss  $dst, $src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10934
  ins_cost(150); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10935
  opcode(0xF3, 0x0F, 0x51);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10936
  ins_encode(OpcP, REX_reg_reg(dst, src), OpcS, OpcT, reg_reg(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10937
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10938
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10939
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10940
instruct sqrtF_mem(regF dst, memory src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10941
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10942
  match(Set dst (ConvD2F (SqrtD (ConvF2D (LoadF src)))));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10943
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10944
  format %{ "sqrtss  $dst, $src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10945
  ins_cost(150); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10946
  opcode(0xF3, 0x0F, 0x51);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10947
  ins_encode(OpcP, REX_reg_mem(dst, src), OpcS, OpcT, reg_mem(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10948
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10949
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10950
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10951
instruct sqrtF_imm(regF dst, immF src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10952
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10953
  match(Set dst (ConvD2F (SqrtD (ConvF2D src))));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10954
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10955
  format %{ "sqrtss  $dst, [$src]" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10956
  ins_cost(150); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10957
  opcode(0xF3, 0x0F, 0x51);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10958
  ins_encode(OpcP, REX_reg_mem(dst, src), OpcS, OpcT, load_immF(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10959
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10960
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10961
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10962
instruct sqrtD_reg(regD dst, regD src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10963
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10964
  match(Set dst (SqrtD src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10965
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10966
  format %{ "sqrtsd  $dst, $src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10967
  ins_cost(150); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10968
  opcode(0xF2, 0x0F, 0x51);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10969
  ins_encode(OpcP, REX_reg_reg(dst, src), OpcS, OpcT, reg_reg(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10970
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10971
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10972
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10973
instruct sqrtD_mem(regD dst, memory src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10974
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10975
  match(Set dst (SqrtD (LoadD src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10976
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10977
  format %{ "sqrtsd  $dst, $src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10978
  ins_cost(150); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10979
  opcode(0xF2, 0x0F, 0x51);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10980
  ins_encode(OpcP, REX_reg_mem(dst, src), OpcS, OpcT, reg_mem(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10981
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10982
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10983
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10984
instruct sqrtD_imm(regD dst, immD src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10985
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10986
  match(Set dst (SqrtD src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10987
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10988
  format %{ "sqrtsd  $dst, [$src]" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10989
  ins_cost(150); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10990
  opcode(0xF2, 0x0F, 0x51);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10991
  ins_encode(OpcP, REX_reg_mem(dst, src), OpcS, OpcT, load_immD(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10992
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10993
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10994
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10995
instruct absF_reg(regF dst)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10996
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10997
  match(Set dst (AbsF dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10998
489c9b5090e2 Initial load
duke
parents:
diff changeset
 10999
  format %{ "andps   $dst, [0x7fffffff]\t# abs float by sign masking" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11000
  ins_encode(absF_encoding(dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11001
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11002
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11003
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11004
instruct absD_reg(regD dst)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11005
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11006
  match(Set dst (AbsD dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11007
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11008
  format %{ "andpd   $dst, [0x7fffffffffffffff]\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11009
            "# abs double by sign masking" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11010
  ins_encode(absD_encoding(dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11011
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11012
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11013
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11014
instruct negF_reg(regF dst)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11015
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11016
  match(Set dst (NegF dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11017
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11018
  format %{ "xorps   $dst, [0x80000000]\t# neg float by sign flipping" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11019
  ins_encode(negF_encoding(dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11020
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11021
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11022
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11023
instruct negD_reg(regD dst)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11024
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11025
  match(Set dst (NegD dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11026
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11027
  format %{ "xorpd   $dst, [0x8000000000000000]\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11028
            "# neg double by sign flipping" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11029
  ins_encode(negD_encoding(dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11030
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11031
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11032
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11033
// -----------Trig and Trancendental Instructions------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11034
instruct cosD_reg(regD dst) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11035
  match(Set dst (CosD dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11036
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11037
  format %{ "dcos   $dst\n\t" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11038
  opcode(0xD9, 0xFF);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11039
  ins_encode( Push_SrcXD(dst), OpcP, OpcS, Push_ResultXD(dst) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11040
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11041
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11042
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11043
instruct sinD_reg(regD dst) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11044
  match(Set dst (SinD dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11045
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11046
  format %{ "dsin   $dst\n\t" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11047
  opcode(0xD9, 0xFE);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11048
  ins_encode( Push_SrcXD(dst), OpcP, OpcS, Push_ResultXD(dst) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11049
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11050
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11051
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11052
instruct tanD_reg(regD dst) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11053
  match(Set dst (TanD dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11054
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11055
  format %{ "dtan   $dst\n\t" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11056
  ins_encode( Push_SrcXD(dst),
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11057
              Opcode(0xD9), Opcode(0xF2),   //fptan
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11058
              Opcode(0xDD), Opcode(0xD8),   //fstp st
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11059
              Push_ResultXD(dst) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11060
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11061
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11062
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11063
instruct log10D_reg(regD dst) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11064
  // The source and result Double operands in XMM registers
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11065
  match(Set dst (Log10D dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11066
  // fldlg2       ; push log_10(2) on the FPU stack; full 80-bit number
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11067
  // fyl2x        ; compute log_10(2) * log_2(x)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11068
  format %{ "fldlg2\t\t\t#Log10\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11069
            "fyl2x\t\t\t# Q=Log10*Log_2(x)\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11070
         %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11071
   ins_encode(Opcode(0xD9), Opcode(0xEC),   // fldlg2
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11072
              Push_SrcXD(dst),
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11073
              Opcode(0xD9), Opcode(0xF1),   // fyl2x
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11074
              Push_ResultXD(dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11075
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11076
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11077
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11078
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11079
instruct logD_reg(regD dst) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11080
  // The source and result Double operands in XMM registers
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11081
  match(Set dst (LogD dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11082
  // fldln2       ; push log_e(2) on the FPU stack; full 80-bit number
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11083
  // fyl2x        ; compute log_e(2) * log_2(x)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11084
  format %{ "fldln2\t\t\t#Log_e\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11085
            "fyl2x\t\t\t# Q=Log_e*Log_2(x)\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11086
         %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11087
  ins_encode( Opcode(0xD9), Opcode(0xED),   // fldln2
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11088
              Push_SrcXD(dst),
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11089
              Opcode(0xD9), Opcode(0xF1),   // fyl2x
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11090
              Push_ResultXD(dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11091
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11092
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11093
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11094
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11095
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11096
//----------Arithmetic Conversion Instructions---------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11097
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11098
instruct roundFloat_nop(regF dst)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11099
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11100
  match(Set dst (RoundFloat dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11101
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11102
  ins_cost(0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11103
  ins_encode();
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11104
  ins_pipe(empty);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11105
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11106
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11107
instruct roundDouble_nop(regD dst)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11108
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11109
  match(Set dst (RoundDouble dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11110
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11111
  ins_cost(0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11112
  ins_encode();
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11113
  ins_pipe(empty);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11114
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11115
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11116
instruct convF2D_reg_reg(regD dst, regF src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11117
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11118
  match(Set dst (ConvF2D src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11119
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11120
  format %{ "cvtss2sd $dst, $src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11121
  opcode(0xF3, 0x0F, 0x5A);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11122
  ins_encode(OpcP, REX_reg_reg(dst, src), OpcS, OpcT, reg_reg(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11123
  ins_pipe(pipe_slow); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11124
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11125
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11126
instruct convF2D_reg_mem(regD dst, memory src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11127
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11128
  match(Set dst (ConvF2D (LoadF src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11129
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11130
  format %{ "cvtss2sd $dst, $src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11131
  opcode(0xF3, 0x0F, 0x5A);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11132
  ins_encode(OpcP, REX_reg_mem(dst, src), OpcS, OpcT, reg_mem(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11133
  ins_pipe(pipe_slow); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11134
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11135
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11136
instruct convD2F_reg_reg(regF dst, regD src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11137
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11138
  match(Set dst (ConvD2F src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11139
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11140
  format %{ "cvtsd2ss $dst, $src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11141
  opcode(0xF2, 0x0F, 0x5A);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11142
  ins_encode(OpcP, REX_reg_reg(dst, src), OpcS, OpcT, reg_reg(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11143
  ins_pipe(pipe_slow); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11144
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11145
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11146
instruct convD2F_reg_mem(regF dst, memory src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11147
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11148
  match(Set dst (ConvD2F (LoadD src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11149
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11150
  format %{ "cvtsd2ss $dst, $src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11151
  opcode(0xF2, 0x0F, 0x5A);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11152
  ins_encode(OpcP, REX_reg_mem(dst, src), OpcS, OpcT, reg_mem(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11153
  ins_pipe(pipe_slow); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11154
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11155
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11156
// XXX do mem variants
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11157
instruct convF2I_reg_reg(rRegI dst, regF src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11158
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11159
  match(Set dst (ConvF2I src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11160
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11161
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11162
  format %{ "cvttss2sil $dst, $src\t# f2i\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11163
            "cmpl    $dst, #0x80000000\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11164
            "jne,s   done\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11165
            "subq    rsp, #8\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11166
            "movss   [rsp], $src\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11167
            "call    f2i_fixup\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11168
            "popq    $dst\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11169
    "done:   "%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11170
  opcode(0xF3, 0x0F, 0x2C);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11171
  ins_encode(OpcP, REX_reg_reg(dst, src), OpcS, OpcT, reg_reg(dst, src),
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11172
             f2i_fixup(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11173
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11174
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11175
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11176
instruct convF2L_reg_reg(rRegL dst, regF src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11177
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11178
  match(Set dst (ConvF2L src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11179
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11180
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11181
  format %{ "cvttss2siq $dst, $src\t# f2l\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11182
            "cmpq    $dst, [0x8000000000000000]\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11183
            "jne,s   done\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11184
            "subq    rsp, #8\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11185
            "movss   [rsp], $src\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11186
            "call    f2l_fixup\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11187
            "popq    $dst\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11188
    "done:   "%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11189
  opcode(0xF3, 0x0F, 0x2C);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11190
  ins_encode(OpcP, REX_reg_reg_wide(dst, src), OpcS, OpcT, reg_reg(dst, src),
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11191
             f2l_fixup(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11192
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11193
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11194
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11195
instruct convD2I_reg_reg(rRegI dst, regD src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11196
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11197
  match(Set dst (ConvD2I src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11198
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11199
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11200
  format %{ "cvttsd2sil $dst, $src\t# d2i\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11201
            "cmpl    $dst, #0x80000000\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11202
            "jne,s   done\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11203
            "subq    rsp, #8\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11204
            "movsd   [rsp], $src\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11205
            "call    d2i_fixup\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11206
            "popq    $dst\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11207
    "done:   "%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11208
  opcode(0xF2, 0x0F, 0x2C);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11209
  ins_encode(OpcP, REX_reg_reg(dst, src), OpcS, OpcT, reg_reg(dst, src),
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11210
             d2i_fixup(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11211
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11212
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11213
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11214
instruct convD2L_reg_reg(rRegL dst, regD src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11215
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11216
  match(Set dst (ConvD2L src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11217
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11218
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11219
  format %{ "cvttsd2siq $dst, $src\t# d2l\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11220
            "cmpq    $dst, [0x8000000000000000]\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11221
            "jne,s   done\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11222
            "subq    rsp, #8\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11223
            "movsd   [rsp], $src\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11224
            "call    d2l_fixup\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11225
            "popq    $dst\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11226
    "done:   "%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11227
  opcode(0xF2, 0x0F, 0x2C);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11228
  ins_encode(OpcP, REX_reg_reg_wide(dst, src), OpcS, OpcT, reg_reg(dst, src),
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11229
             d2l_fixup(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11230
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11231
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11232
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11233
instruct convI2F_reg_reg(regF dst, rRegI src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11234
%{
244
c8ad6f221400 6662967: Optimize I2D conversion on new x86
kvn
parents: 1
diff changeset
 11235
  predicate(!UseXmmI2F);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11236
  match(Set dst (ConvI2F src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11237
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11238
  format %{ "cvtsi2ssl $dst, $src\t# i2f" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11239
  opcode(0xF3, 0x0F, 0x2A);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11240
  ins_encode(OpcP, REX_reg_reg(dst, src), OpcS, OpcT, reg_reg(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11241
  ins_pipe(pipe_slow); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11242
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11243
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11244
instruct convI2F_reg_mem(regF dst, memory src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11245
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11246
  match(Set dst (ConvI2F (LoadI src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11247
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11248
  format %{ "cvtsi2ssl $dst, $src\t# i2f" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11249
  opcode(0xF3, 0x0F, 0x2A);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11250
  ins_encode(OpcP, REX_reg_mem(dst, src), OpcS, OpcT, reg_mem(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11251
  ins_pipe(pipe_slow); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11252
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11253
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11254
instruct convI2D_reg_reg(regD dst, rRegI src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11255
%{
244
c8ad6f221400 6662967: Optimize I2D conversion on new x86
kvn
parents: 1
diff changeset
 11256
  predicate(!UseXmmI2D);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11257
  match(Set dst (ConvI2D src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11258
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11259
  format %{ "cvtsi2sdl $dst, $src\t# i2d" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11260
  opcode(0xF2, 0x0F, 0x2A);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11261
  ins_encode(OpcP, REX_reg_reg(dst, src), OpcS, OpcT, reg_reg(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11262
  ins_pipe(pipe_slow); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11263
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11264
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11265
instruct convI2D_reg_mem(regD dst, memory src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11266
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11267
  match(Set dst (ConvI2D (LoadI src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11268
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11269
  format %{ "cvtsi2sdl $dst, $src\t# i2d" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11270
  opcode(0xF2, 0x0F, 0x2A);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11271
  ins_encode(OpcP, REX_reg_mem(dst, src), OpcS, OpcT, reg_mem(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11272
  ins_pipe(pipe_slow); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11273
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11274
244
c8ad6f221400 6662967: Optimize I2D conversion on new x86
kvn
parents: 1
diff changeset
 11275
instruct convXI2F_reg(regF dst, rRegI src)
c8ad6f221400 6662967: Optimize I2D conversion on new x86
kvn
parents: 1
diff changeset
 11276
%{
c8ad6f221400 6662967: Optimize I2D conversion on new x86
kvn
parents: 1
diff changeset
 11277
  predicate(UseXmmI2F);
c8ad6f221400 6662967: Optimize I2D conversion on new x86
kvn
parents: 1
diff changeset
 11278
  match(Set dst (ConvI2F src));
c8ad6f221400 6662967: Optimize I2D conversion on new x86
kvn
parents: 1
diff changeset
 11279
c8ad6f221400 6662967: Optimize I2D conversion on new x86
kvn
parents: 1
diff changeset
 11280
  format %{ "movdl $dst, $src\n\t"
c8ad6f221400 6662967: Optimize I2D conversion on new x86
kvn
parents: 1
diff changeset
 11281
            "cvtdq2psl $dst, $dst\t# i2f" %}
c8ad6f221400 6662967: Optimize I2D conversion on new x86
kvn
parents: 1
diff changeset
 11282
  ins_encode %{
c8ad6f221400 6662967: Optimize I2D conversion on new x86
kvn
parents: 1
diff changeset
 11283
    __ movdl($dst$$XMMRegister, $src$$Register);
c8ad6f221400 6662967: Optimize I2D conversion on new x86
kvn
parents: 1
diff changeset
 11284
    __ cvtdq2ps($dst$$XMMRegister, $dst$$XMMRegister);
c8ad6f221400 6662967: Optimize I2D conversion on new x86
kvn
parents: 1
diff changeset
 11285
  %}
c8ad6f221400 6662967: Optimize I2D conversion on new x86
kvn
parents: 1
diff changeset
 11286
  ins_pipe(pipe_slow); // XXX
c8ad6f221400 6662967: Optimize I2D conversion on new x86
kvn
parents: 1
diff changeset
 11287
%}
c8ad6f221400 6662967: Optimize I2D conversion on new x86
kvn
parents: 1
diff changeset
 11288
c8ad6f221400 6662967: Optimize I2D conversion on new x86
kvn
parents: 1
diff changeset
 11289
instruct convXI2D_reg(regD dst, rRegI src)
c8ad6f221400 6662967: Optimize I2D conversion on new x86
kvn
parents: 1
diff changeset
 11290
%{
c8ad6f221400 6662967: Optimize I2D conversion on new x86
kvn
parents: 1
diff changeset
 11291
  predicate(UseXmmI2D);
c8ad6f221400 6662967: Optimize I2D conversion on new x86
kvn
parents: 1
diff changeset
 11292
  match(Set dst (ConvI2D src));
c8ad6f221400 6662967: Optimize I2D conversion on new x86
kvn
parents: 1
diff changeset
 11293
c8ad6f221400 6662967: Optimize I2D conversion on new x86
kvn
parents: 1
diff changeset
 11294
  format %{ "movdl $dst, $src\n\t"
c8ad6f221400 6662967: Optimize I2D conversion on new x86
kvn
parents: 1
diff changeset
 11295
            "cvtdq2pdl $dst, $dst\t# i2d" %}
c8ad6f221400 6662967: Optimize I2D conversion on new x86
kvn
parents: 1
diff changeset
 11296
  ins_encode %{
c8ad6f221400 6662967: Optimize I2D conversion on new x86
kvn
parents: 1
diff changeset
 11297
    __ movdl($dst$$XMMRegister, $src$$Register);
c8ad6f221400 6662967: Optimize I2D conversion on new x86
kvn
parents: 1
diff changeset
 11298
    __ cvtdq2pd($dst$$XMMRegister, $dst$$XMMRegister);
c8ad6f221400 6662967: Optimize I2D conversion on new x86
kvn
parents: 1
diff changeset
 11299
  %}
c8ad6f221400 6662967: Optimize I2D conversion on new x86
kvn
parents: 1
diff changeset
 11300
  ins_pipe(pipe_slow); // XXX
c8ad6f221400 6662967: Optimize I2D conversion on new x86
kvn
parents: 1
diff changeset
 11301
%}
c8ad6f221400 6662967: Optimize I2D conversion on new x86
kvn
parents: 1
diff changeset
 11302
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11303
instruct convL2F_reg_reg(regF dst, rRegL src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11304
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11305
  match(Set dst (ConvL2F src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11306
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11307
  format %{ "cvtsi2ssq $dst, $src\t# l2f" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11308
  opcode(0xF3, 0x0F, 0x2A);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11309
  ins_encode(OpcP, REX_reg_reg_wide(dst, src), OpcS, OpcT, reg_reg(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11310
  ins_pipe(pipe_slow); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11311
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11312
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11313
instruct convL2F_reg_mem(regF dst, memory src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11314
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11315
  match(Set dst (ConvL2F (LoadL src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11316
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11317
  format %{ "cvtsi2ssq $dst, $src\t# l2f" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11318
  opcode(0xF3, 0x0F, 0x2A);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11319
  ins_encode(OpcP, REX_reg_mem_wide(dst, src), OpcS, OpcT, reg_mem(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11320
  ins_pipe(pipe_slow); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11321
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11322
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11323
instruct convL2D_reg_reg(regD dst, rRegL src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11324
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11325
  match(Set dst (ConvL2D src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11326
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11327
  format %{ "cvtsi2sdq $dst, $src\t# l2d" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11328
  opcode(0xF2, 0x0F, 0x2A);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11329
  ins_encode(OpcP, REX_reg_reg_wide(dst, src), OpcS, OpcT, reg_reg(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11330
  ins_pipe(pipe_slow); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11331
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11332
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11333
instruct convL2D_reg_mem(regD dst, memory src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11334
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11335
  match(Set dst (ConvL2D (LoadL src)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11336
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11337
  format %{ "cvtsi2sdq $dst, $src\t# l2d" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11338
  opcode(0xF2, 0x0F, 0x2A);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11339
  ins_encode(OpcP, REX_reg_mem_wide(dst, src), OpcS, OpcT, reg_mem(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11340
  ins_pipe(pipe_slow); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11341
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11342
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11343
instruct convI2L_reg_reg(rRegL dst, rRegI src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11344
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11345
  match(Set dst (ConvI2L src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11346
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11347
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11348
  format %{ "movslq  $dst, $src\t# i2l" %}
3177
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
 11349
  ins_encode %{
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
 11350
    __ movslq($dst$$Register, $src$$Register);
f467776fc753 5057225: Remove useless I2L conversions
twisti
parents: 2872
diff changeset
 11351
  %}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11352
  ins_pipe(ialu_reg_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11353
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11354
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11355
// instruct convI2L_reg_reg_foo(rRegL dst, rRegI src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11356
// %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11357
//   match(Set dst (ConvI2L src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11358
// //   predicate(_kids[0]->_leaf->as_Type()->type()->is_int()->_lo >= 0 &&
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11359
// //             _kids[0]->_leaf->as_Type()->type()->is_int()->_hi >= 0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11360
//   predicate(((const TypeNode*) n)->type()->is_long()->_hi ==
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11361
//             (unsigned int) ((const TypeNode*) n)->type()->is_long()->_hi &&
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11362
//             ((const TypeNode*) n)->type()->is_long()->_lo ==
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11363
//             (unsigned int) ((const TypeNode*) n)->type()->is_long()->_lo);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11364
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11365
//   format %{ "movl    $dst, $src\t# unsigned i2l" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11366
//   ins_encode(enc_copy(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11367
// //   opcode(0x63); // needs REX.W
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11368
// //   ins_encode(REX_reg_reg_wide(dst, src), OpcP, reg_reg(dst,src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11369
//   ins_pipe(ialu_reg_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11370
// %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11371
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11372
// Zero-extend convert int to long
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11373
instruct convI2L_reg_reg_zex(rRegL dst, rRegI src, immL_32bits mask)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11374
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11375
  match(Set dst (AndL (ConvI2L src) mask));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11376
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11377
  format %{ "movl    $dst, $src\t# i2l zero-extend\n\t" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11378
  ins_encode(enc_copy(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11379
  ins_pipe(ialu_reg_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11380
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11381
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11382
// Zero-extend convert int to long
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11383
instruct convI2L_reg_mem_zex(rRegL dst, memory src, immL_32bits mask)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11384
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11385
  match(Set dst (AndL (ConvI2L (LoadI src)) mask));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11386
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11387
  format %{ "movl    $dst, $src\t# i2l zero-extend\n\t" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11388
  opcode(0x8B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11389
  ins_encode(REX_reg_mem(dst, src), OpcP, reg_mem(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11390
  ins_pipe(ialu_reg_mem);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11391
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11392
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11393
instruct zerox_long_reg_reg(rRegL dst, rRegL src, immL_32bits mask)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11394
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11395
  match(Set dst (AndL src mask));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11396
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11397
  format %{ "movl    $dst, $src\t# zero-extend long" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11398
  ins_encode(enc_copy_always(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11399
  ins_pipe(ialu_reg_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11400
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11401
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11402
instruct convL2I_reg_reg(rRegI dst, rRegL src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11403
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11404
  match(Set dst (ConvL2I src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11405
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11406
  format %{ "movl    $dst, $src\t# l2i" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11407
  ins_encode(enc_copy_always(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11408
  ins_pipe(ialu_reg_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11409
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11410
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11411
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11412
instruct MoveF2I_stack_reg(rRegI dst, stackSlotF src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11413
  match(Set dst (MoveF2I src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11414
  effect(DEF dst, USE src);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11415
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11416
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11417
  format %{ "movl    $dst, $src\t# MoveF2I_stack_reg" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11418
  opcode(0x8B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11419
  ins_encode(REX_reg_mem(dst, src), OpcP, reg_mem(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11420
  ins_pipe(ialu_reg_mem);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11421
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11422
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11423
instruct MoveI2F_stack_reg(regF dst, stackSlotI src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11424
  match(Set dst (MoveI2F src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11425
  effect(DEF dst, USE src);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11426
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11427
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11428
  format %{ "movss   $dst, $src\t# MoveI2F_stack_reg" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11429
  opcode(0xF3, 0x0F, 0x10);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11430
  ins_encode(OpcP, REX_reg_mem(dst, src), OpcS, OpcT, reg_mem(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11431
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11432
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11433
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11434
instruct MoveD2L_stack_reg(rRegL dst, stackSlotD src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11435
  match(Set dst (MoveD2L src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11436
  effect(DEF dst, USE src);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11437
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11438
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11439
  format %{ "movq    $dst, $src\t# MoveD2L_stack_reg" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11440
  opcode(0x8B);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11441
  ins_encode(REX_reg_mem_wide(dst, src), OpcP, reg_mem(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11442
  ins_pipe(ialu_reg_mem);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11443
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11444
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11445
instruct MoveL2D_stack_reg_partial(regD dst, stackSlotL src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11446
  predicate(!UseXmmLoadAndClearUpper);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11447
  match(Set dst (MoveL2D src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11448
  effect(DEF dst, USE src);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11449
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11450
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11451
  format %{ "movlpd  $dst, $src\t# MoveL2D_stack_reg" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11452
  opcode(0x66, 0x0F, 0x12);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11453
  ins_encode(OpcP, REX_reg_mem(dst, src), OpcS, OpcT, reg_mem(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11454
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11455
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11456
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11457
instruct MoveL2D_stack_reg(regD dst, stackSlotL src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11458
  predicate(UseXmmLoadAndClearUpper);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11459
  match(Set dst (MoveL2D src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11460
  effect(DEF dst, USE src);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11461
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11462
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11463
  format %{ "movsd   $dst, $src\t# MoveL2D_stack_reg" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11464
  opcode(0xF2, 0x0F, 0x10);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11465
  ins_encode(OpcP, REX_reg_mem(dst, src), OpcS, OpcT, reg_mem(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11466
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11467
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11468
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11469
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11470
instruct MoveF2I_reg_stack(stackSlotI dst, regF src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11471
  match(Set dst (MoveF2I src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11472
  effect(DEF dst, USE src);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11473
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11474
  ins_cost(95); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11475
  format %{ "movss   $dst, $src\t# MoveF2I_reg_stack" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11476
  opcode(0xF3, 0x0F, 0x11);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11477
  ins_encode(OpcP, REX_reg_mem(src, dst), OpcS, OpcT, reg_mem(src, dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11478
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11479
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11480
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11481
instruct MoveI2F_reg_stack(stackSlotF dst, rRegI src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11482
  match(Set dst (MoveI2F src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11483
  effect(DEF dst, USE src);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11484
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11485
  ins_cost(100);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11486
  format %{ "movl    $dst, $src\t# MoveI2F_reg_stack" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11487
  opcode(0x89);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11488
  ins_encode(REX_reg_mem(src, dst), OpcP, reg_mem(src, dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11489
  ins_pipe( ialu_mem_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11490
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11491
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11492
instruct MoveD2L_reg_stack(stackSlotL dst, regD src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11493
  match(Set dst (MoveD2L src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11494
  effect(DEF dst, USE src);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11495
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11496
  ins_cost(95); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11497
  format %{ "movsd   $dst, $src\t# MoveL2D_reg_stack" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11498
  opcode(0xF2, 0x0F, 0x11);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11499
  ins_encode(OpcP, REX_reg_mem(src, dst), OpcS, OpcT, reg_mem(src, dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11500
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11501
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11502
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11503
instruct MoveL2D_reg_stack(stackSlotD dst, rRegL src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11504
  match(Set dst (MoveL2D src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11505
  effect(DEF dst, USE src);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11506
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11507
  ins_cost(100);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11508
  format %{ "movq    $dst, $src\t# MoveL2D_reg_stack" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11509
  opcode(0x89);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11510
  ins_encode(REX_reg_mem_wide(src, dst), OpcP, reg_mem(src, dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11511
  ins_pipe(ialu_mem_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11512
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11513
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11514
instruct MoveF2I_reg_reg(rRegI dst, regF src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11515
  match(Set dst (MoveF2I src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11516
  effect(DEF dst, USE src);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11517
  ins_cost(85);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11518
  format %{ "movd    $dst,$src\t# MoveF2I" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11519
  ins_encode %{ __ movdl($dst$$Register, $src$$XMMRegister); %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11520
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11521
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11522
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11523
instruct MoveD2L_reg_reg(rRegL dst, regD src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11524
  match(Set dst (MoveD2L src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11525
  effect(DEF dst, USE src);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11526
  ins_cost(85);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11527
  format %{ "movd    $dst,$src\t# MoveD2L" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11528
  ins_encode %{ __ movdq($dst$$Register, $src$$XMMRegister); %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11529
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11530
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11531
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11532
// The next instructions have long latency and use Int unit. Set high cost.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11533
instruct MoveI2F_reg_reg(regF dst, rRegI src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11534
  match(Set dst (MoveI2F src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11535
  effect(DEF dst, USE src);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11536
  ins_cost(300);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11537
  format %{ "movd    $dst,$src\t# MoveI2F" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11538
  ins_encode %{ __ movdl($dst$$XMMRegister, $src$$Register); %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11539
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11540
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11541
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11542
instruct MoveL2D_reg_reg(regD dst, rRegL src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11543
  match(Set dst (MoveL2D src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11544
  effect(DEF dst, USE src);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11545
  ins_cost(300);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11546
  format %{ "movd    $dst,$src\t# MoveL2D" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11547
  ins_encode %{ __ movdq($dst$$XMMRegister, $src$$Register); %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11548
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11549
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11550
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11551
// Replicate scalar to packed byte (1 byte) values in xmm
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11552
instruct Repl8B_reg(regD dst, regD src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11553
  match(Set dst (Replicate8B src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11554
  format %{ "MOVDQA  $dst,$src\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11555
            "PUNPCKLBW $dst,$dst\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11556
            "PSHUFLW $dst,$dst,0x00\t! replicate8B" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11557
  ins_encode( pshufd_8x8(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11558
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11559
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11560
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11561
// Replicate scalar to packed byte (1 byte) values in xmm
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11562
instruct Repl8B_rRegI(regD dst, rRegI src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11563
  match(Set dst (Replicate8B src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11564
  format %{ "MOVD    $dst,$src\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11565
            "PUNPCKLBW $dst,$dst\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11566
            "PSHUFLW $dst,$dst,0x00\t! replicate8B" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11567
  ins_encode( mov_i2x(dst, src), pshufd_8x8(dst, dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11568
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11569
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11570
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11571
// Replicate scalar zero to packed byte (1 byte) values in xmm
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11572
instruct Repl8B_immI0(regD dst, immI0 zero) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11573
  match(Set dst (Replicate8B zero));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11574
  format %{ "PXOR  $dst,$dst\t! replicate8B" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11575
  ins_encode( pxor(dst, dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11576
  ins_pipe( fpu_reg_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11577
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11578
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11579
// Replicate scalar to packed shore (2 byte) values in xmm
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11580
instruct Repl4S_reg(regD dst, regD src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11581
  match(Set dst (Replicate4S src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11582
  format %{ "PSHUFLW $dst,$src,0x00\t! replicate4S" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11583
  ins_encode( pshufd_4x16(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11584
  ins_pipe( fpu_reg_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11585
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11586
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11587
// Replicate scalar to packed shore (2 byte) values in xmm
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11588
instruct Repl4S_rRegI(regD dst, rRegI src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11589
  match(Set dst (Replicate4S src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11590
  format %{ "MOVD    $dst,$src\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11591
            "PSHUFLW $dst,$dst,0x00\t! replicate4S" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11592
  ins_encode( mov_i2x(dst, src), pshufd_4x16(dst, dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11593
  ins_pipe( fpu_reg_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11594
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11595
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11596
// Replicate scalar zero to packed short (2 byte) values in xmm
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11597
instruct Repl4S_immI0(regD dst, immI0 zero) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11598
  match(Set dst (Replicate4S zero));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11599
  format %{ "PXOR  $dst,$dst\t! replicate4S" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11600
  ins_encode( pxor(dst, dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11601
  ins_pipe( fpu_reg_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11602
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11603
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11604
// Replicate scalar to packed char (2 byte) values in xmm
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11605
instruct Repl4C_reg(regD dst, regD src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11606
  match(Set dst (Replicate4C src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11607
  format %{ "PSHUFLW $dst,$src,0x00\t! replicate4C" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11608
  ins_encode( pshufd_4x16(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11609
  ins_pipe( fpu_reg_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11610
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11611
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11612
// Replicate scalar to packed char (2 byte) values in xmm
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11613
instruct Repl4C_rRegI(regD dst, rRegI src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11614
  match(Set dst (Replicate4C src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11615
  format %{ "MOVD    $dst,$src\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11616
            "PSHUFLW $dst,$dst,0x00\t! replicate4C" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11617
  ins_encode( mov_i2x(dst, src), pshufd_4x16(dst, dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11618
  ins_pipe( fpu_reg_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11619
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11620
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11621
// Replicate scalar zero to packed char (2 byte) values in xmm
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11622
instruct Repl4C_immI0(regD dst, immI0 zero) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11623
  match(Set dst (Replicate4C zero));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11624
  format %{ "PXOR  $dst,$dst\t! replicate4C" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11625
  ins_encode( pxor(dst, dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11626
  ins_pipe( fpu_reg_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11627
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11628
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11629
// Replicate scalar to packed integer (4 byte) values in xmm
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11630
instruct Repl2I_reg(regD dst, regD src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11631
  match(Set dst (Replicate2I src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11632
  format %{ "PSHUFD $dst,$src,0x00\t! replicate2I" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11633
  ins_encode( pshufd(dst, src, 0x00));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11634
  ins_pipe( fpu_reg_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11635
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11636
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11637
// Replicate scalar to packed integer (4 byte) values in xmm
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11638
instruct Repl2I_rRegI(regD dst, rRegI src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11639
  match(Set dst (Replicate2I src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11640
  format %{ "MOVD   $dst,$src\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11641
            "PSHUFD $dst,$dst,0x00\t! replicate2I" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11642
  ins_encode( mov_i2x(dst, src), pshufd(dst, dst, 0x00));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11643
  ins_pipe( fpu_reg_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11644
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11645
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11646
// Replicate scalar zero to packed integer (2 byte) values in xmm
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11647
instruct Repl2I_immI0(regD dst, immI0 zero) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11648
  match(Set dst (Replicate2I zero));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11649
  format %{ "PXOR  $dst,$dst\t! replicate2I" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11650
  ins_encode( pxor(dst, dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11651
  ins_pipe( fpu_reg_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11652
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11653
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11654
// Replicate scalar to packed single precision floating point values in xmm
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11655
instruct Repl2F_reg(regD dst, regD src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11656
  match(Set dst (Replicate2F src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11657
  format %{ "PSHUFD $dst,$src,0xe0\t! replicate2F" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11658
  ins_encode( pshufd(dst, src, 0xe0));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11659
  ins_pipe( fpu_reg_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11660
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11661
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11662
// Replicate scalar to packed single precision floating point values in xmm
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11663
instruct Repl2F_regF(regD dst, regF src) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11664
  match(Set dst (Replicate2F src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11665
  format %{ "PSHUFD $dst,$src,0xe0\t! replicate2F" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11666
  ins_encode( pshufd(dst, src, 0xe0));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11667
  ins_pipe( fpu_reg_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11668
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11669
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11670
// Replicate scalar to packed single precision floating point values in xmm
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11671
instruct Repl2F_immF0(regD dst, immF0 zero) %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11672
  match(Set dst (Replicate2F zero));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11673
  format %{ "PXOR  $dst,$dst\t! replicate2F" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11674
  ins_encode( pxor(dst, dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11675
  ins_pipe( fpu_reg_reg );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11676
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11677
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11678
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11679
// =======================================================================
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11680
// fast clearing of an array
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11681
instruct rep_stos(rcx_RegL cnt, rdi_RegP base, rax_RegI zero, Universe dummy,
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11682
                  rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11683
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11684
  match(Set dummy (ClearArray cnt base));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11685
  effect(USE_KILL cnt, USE_KILL base, KILL zero, KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11686
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11687
  format %{ "xorl    rax, rax\t# ClearArray:\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11688
            "rep stosq\t# Store rax to *rdi++ while rcx--" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11689
  ins_encode(opc_reg_reg(0x33, RAX, RAX), // xorl %eax, %eax
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11690
             Opcode(0xF3), Opcode(0x48), Opcode(0xAB)); // rep REX_W stos
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11691
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11692
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11693
3905
7d725029ac85 6827605: new String intrinsics may prevent EA scalar replacement
kvn
parents: 3177
diff changeset
 11694
instruct string_compare(rdi_RegP str1, rcx_RegI cnt1, rsi_RegP str2, rbx_RegI cnt2,
7d725029ac85 6827605: new String intrinsics may prevent EA scalar replacement
kvn
parents: 3177
diff changeset
 11695
                        rax_RegI result, regD tmp1, regD tmp2, rFlagsReg cr)
7d725029ac85 6827605: new String intrinsics may prevent EA scalar replacement
kvn
parents: 3177
diff changeset
 11696
%{
7d725029ac85 6827605: new String intrinsics may prevent EA scalar replacement
kvn
parents: 3177
diff changeset
 11697
  match(Set result (StrComp (Binary str1 cnt1) (Binary str2 cnt2)));
7d725029ac85 6827605: new String intrinsics may prevent EA scalar replacement
kvn
parents: 3177
diff changeset
 11698
  effect(TEMP tmp1, TEMP tmp2, USE_KILL str1, USE_KILL str2, USE_KILL cnt1, USE_KILL cnt2, KILL cr);
7d725029ac85 6827605: new String intrinsics may prevent EA scalar replacement
kvn
parents: 3177
diff changeset
 11699
7d725029ac85 6827605: new String intrinsics may prevent EA scalar replacement
kvn
parents: 3177
diff changeset
 11700
  format %{ "String Compare $str1,$cnt1,$str2,$cnt2 -> $result   // KILL $tmp1, $tmp2" %}
7d725029ac85 6827605: new String intrinsics may prevent EA scalar replacement
kvn
parents: 3177
diff changeset
 11701
  ins_encode %{
7d725029ac85 6827605: new String intrinsics may prevent EA scalar replacement
kvn
parents: 3177
diff changeset
 11702
    __ string_compare($str1$$Register, $str2$$Register,
7d725029ac85 6827605: new String intrinsics may prevent EA scalar replacement
kvn
parents: 3177
diff changeset
 11703
                      $cnt1$$Register, $cnt2$$Register, $result$$Register,
7d725029ac85 6827605: new String intrinsics may prevent EA scalar replacement
kvn
parents: 3177
diff changeset
 11704
                      $tmp1$$XMMRegister, $tmp2$$XMMRegister);
7d725029ac85 6827605: new String intrinsics may prevent EA scalar replacement
kvn
parents: 3177
diff changeset
 11705
  %}
2348
4e71ed4c2709 6761600: Use sse 4.2 in intrinsics
cfang
parents: 2338
diff changeset
 11706
  ins_pipe( pipe_slow );
4e71ed4c2709 6761600: Use sse 4.2 in intrinsics
cfang
parents: 2338
diff changeset
 11707
%}
4e71ed4c2709 6761600: Use sse 4.2 in intrinsics
cfang
parents: 2338
diff changeset
 11708
3905
7d725029ac85 6827605: new String intrinsics may prevent EA scalar replacement
kvn
parents: 3177
diff changeset
 11709
instruct string_indexof(rdi_RegP str1, rdx_RegI cnt1, rsi_RegP str2, rax_RegI cnt2,
7d725029ac85 6827605: new String intrinsics may prevent EA scalar replacement
kvn
parents: 3177
diff changeset
 11710
                        rbx_RegI result, regD tmp1, rcx_RegI tmp2, rFlagsReg cr)
2348
4e71ed4c2709 6761600: Use sse 4.2 in intrinsics
cfang
parents: 2338
diff changeset
 11711
%{
4e71ed4c2709 6761600: Use sse 4.2 in intrinsics
cfang
parents: 2338
diff changeset
 11712
  predicate(UseSSE42Intrinsics);
3905
7d725029ac85 6827605: new String intrinsics may prevent EA scalar replacement
kvn
parents: 3177
diff changeset
 11713
  match(Set result (StrIndexOf (Binary str1 cnt1) (Binary str2 cnt2)));
7d725029ac85 6827605: new String intrinsics may prevent EA scalar replacement
kvn
parents: 3177
diff changeset
 11714
  effect(TEMP tmp1, USE_KILL str1, USE_KILL str2, USE_KILL cnt1, USE_KILL cnt2, KILL tmp2, KILL cr);
7d725029ac85 6827605: new String intrinsics may prevent EA scalar replacement
kvn
parents: 3177
diff changeset
 11715
7d725029ac85 6827605: new String intrinsics may prevent EA scalar replacement
kvn
parents: 3177
diff changeset
 11716
  format %{ "String IndexOf $str1,$cnt1,$str2,$cnt2 -> $result   // KILL $tmp1, $tmp2" %}
7d725029ac85 6827605: new String intrinsics may prevent EA scalar replacement
kvn
parents: 3177
diff changeset
 11717
  ins_encode %{
7d725029ac85 6827605: new String intrinsics may prevent EA scalar replacement
kvn
parents: 3177
diff changeset
 11718
    __ string_indexof($str1$$Register, $str2$$Register,
7d725029ac85 6827605: new String intrinsics may prevent EA scalar replacement
kvn
parents: 3177
diff changeset
 11719
                      $cnt1$$Register, $cnt2$$Register, $result$$Register,
7d725029ac85 6827605: new String intrinsics may prevent EA scalar replacement
kvn
parents: 3177
diff changeset
 11720
                      $tmp1$$XMMRegister, $tmp2$$Register);
7d725029ac85 6827605: new String intrinsics may prevent EA scalar replacement
kvn
parents: 3177
diff changeset
 11721
  %}
2348
4e71ed4c2709 6761600: Use sse 4.2 in intrinsics
cfang
parents: 2338
diff changeset
 11722
  ins_pipe( pipe_slow );
4e71ed4c2709 6761600: Use sse 4.2 in intrinsics
cfang
parents: 2338
diff changeset
 11723
%}
4e71ed4c2709 6761600: Use sse 4.2 in intrinsics
cfang
parents: 2338
diff changeset
 11724
4e71ed4c2709 6761600: Use sse 4.2 in intrinsics
cfang
parents: 2338
diff changeset
 11725
// fast string equals
3905
7d725029ac85 6827605: new String intrinsics may prevent EA scalar replacement
kvn
parents: 3177
diff changeset
 11726
instruct string_equals(rdi_RegP str1, rsi_RegP str2, rcx_RegI cnt, rax_RegI result,
7d725029ac85 6827605: new String intrinsics may prevent EA scalar replacement
kvn
parents: 3177
diff changeset
 11727
                       regD tmp1, regD tmp2, rbx_RegI tmp3, rFlagsReg cr)
7d725029ac85 6827605: new String intrinsics may prevent EA scalar replacement
kvn
parents: 3177
diff changeset
 11728
%{
7d725029ac85 6827605: new String intrinsics may prevent EA scalar replacement
kvn
parents: 3177
diff changeset
 11729
  match(Set result (StrEquals (Binary str1 str2) cnt));
7d725029ac85 6827605: new String intrinsics may prevent EA scalar replacement
kvn
parents: 3177
diff changeset
 11730
  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
 11731
7d725029ac85 6827605: new String intrinsics may prevent EA scalar replacement
kvn
parents: 3177
diff changeset
 11732
  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
 11733
  ins_encode %{
7d725029ac85 6827605: new String intrinsics may prevent EA scalar replacement
kvn
parents: 3177
diff changeset
 11734
    __ char_arrays_equals(false, $str1$$Register, $str2$$Register,
7d725029ac85 6827605: new String intrinsics may prevent EA scalar replacement
kvn
parents: 3177
diff changeset
 11735
                          $cnt$$Register, $result$$Register, $tmp3$$Register,
7d725029ac85 6827605: new String intrinsics may prevent EA scalar replacement
kvn
parents: 3177
diff changeset
 11736
                          $tmp1$$XMMRegister, $tmp2$$XMMRegister);
7d725029ac85 6827605: new String intrinsics may prevent EA scalar replacement
kvn
parents: 3177
diff changeset
 11737
  %}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11738
  ins_pipe( pipe_slow );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11739
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11740
595
a2be4c89de81 6695049: (coll) Create an x86 intrinsic for Arrays.equals
rasbold
parents: 594
diff changeset
 11741
// fast array equals
3905
7d725029ac85 6827605: new String intrinsics may prevent EA scalar replacement
kvn
parents: 3177
diff changeset
 11742
instruct array_equals(rdi_RegP ary1, rsi_RegP ary2, rax_RegI result,
7d725029ac85 6827605: new String intrinsics may prevent EA scalar replacement
kvn
parents: 3177
diff changeset
 11743
                      regD tmp1, regD tmp2, rcx_RegI tmp3, rbx_RegI tmp4, rFlagsReg cr)
2348
4e71ed4c2709 6761600: Use sse 4.2 in intrinsics
cfang
parents: 2338
diff changeset
 11744
%{
595
a2be4c89de81 6695049: (coll) Create an x86 intrinsic for Arrays.equals
rasbold
parents: 594
diff changeset
 11745
  match(Set result (AryEq ary1 ary2));
2348
4e71ed4c2709 6761600: Use sse 4.2 in intrinsics
cfang
parents: 2338
diff changeset
 11746
  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: 594
diff changeset
 11747
  //ins_cost(300);
a2be4c89de81 6695049: (coll) Create an x86 intrinsic for Arrays.equals
rasbold
parents: 594
diff changeset
 11748
3905
7d725029ac85 6827605: new String intrinsics may prevent EA scalar replacement
kvn
parents: 3177
diff changeset
 11749
  format %{ "Array Equals $ary1,$ary2 -> $result   // KILL $tmp1, $tmp2, $tmp3, $tmp4" %}
7d725029ac85 6827605: new String intrinsics may prevent EA scalar replacement
kvn
parents: 3177
diff changeset
 11750
  ins_encode %{
7d725029ac85 6827605: new String intrinsics may prevent EA scalar replacement
kvn
parents: 3177
diff changeset
 11751
    __ char_arrays_equals(true, $ary1$$Register, $ary2$$Register,
7d725029ac85 6827605: new String intrinsics may prevent EA scalar replacement
kvn
parents: 3177
diff changeset
 11752
                          $tmp3$$Register, $result$$Register, $tmp4$$Register,
7d725029ac85 6827605: new String intrinsics may prevent EA scalar replacement
kvn
parents: 3177
diff changeset
 11753
                          $tmp1$$XMMRegister, $tmp2$$XMMRegister);
7d725029ac85 6827605: new String intrinsics may prevent EA scalar replacement
kvn
parents: 3177
diff changeset
 11754
  %}
595
a2be4c89de81 6695049: (coll) Create an x86 intrinsic for Arrays.equals
rasbold
parents: 594
diff changeset
 11755
  ins_pipe( pipe_slow );
a2be4c89de81 6695049: (coll) Create an x86 intrinsic for Arrays.equals
rasbold
parents: 594
diff changeset
 11756
%}
a2be4c89de81 6695049: (coll) Create an x86 intrinsic for Arrays.equals
rasbold
parents: 594
diff changeset
 11757
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11758
//----------Control Flow Instructions------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11759
// Signed compare Instructions
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11760
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11761
// XXX more variants!!
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11762
instruct compI_rReg(rFlagsReg cr, rRegI op1, rRegI op2)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11763
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11764
  match(Set cr (CmpI op1 op2));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11765
  effect(DEF cr, USE op1, USE op2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11766
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11767
  format %{ "cmpl    $op1, $op2" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11768
  opcode(0x3B);  /* Opcode 3B /r */
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11769
  ins_encode(REX_reg_reg(op1, op2), OpcP, reg_reg(op1, op2));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11770
  ins_pipe(ialu_cr_reg_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11771
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11772
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11773
instruct compI_rReg_imm(rFlagsReg cr, rRegI op1, immI op2)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11774
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11775
  match(Set cr (CmpI op1 op2));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11776
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11777
  format %{ "cmpl    $op1, $op2" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11778
  opcode(0x81, 0x07); /* Opcode 81 /7 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11779
  ins_encode(OpcSErm(op1, op2), Con8or32(op2));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11780
  ins_pipe(ialu_cr_reg_imm);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11781
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11782
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11783
instruct compI_rReg_mem(rFlagsReg cr, rRegI op1, memory op2)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11784
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11785
  match(Set cr (CmpI op1 (LoadI op2)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11786
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11787
  ins_cost(500); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11788
  format %{ "cmpl    $op1, $op2" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11789
  opcode(0x3B); /* Opcode 3B /r */
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11790
  ins_encode(REX_reg_mem(op1, op2), OpcP, reg_mem(op1, op2));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11791
  ins_pipe(ialu_cr_reg_mem);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11792
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11793
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11794
instruct testI_reg(rFlagsReg cr, rRegI src, immI0 zero)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11795
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11796
  match(Set cr (CmpI src zero));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11797
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11798
  format %{ "testl   $src, $src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11799
  opcode(0x85);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11800
  ins_encode(REX_reg_reg(src, src), OpcP, reg_reg(src, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11801
  ins_pipe(ialu_cr_reg_imm);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11802
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11803
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11804
instruct testI_reg_imm(rFlagsReg cr, rRegI src, immI con, immI0 zero)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11805
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11806
  match(Set cr (CmpI (AndI src con) zero));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11807
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11808
  format %{ "testl   $src, $con" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11809
  opcode(0xF7, 0x00);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11810
  ins_encode(REX_reg(src), OpcP, reg_opc(src), Con32(con));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11811
  ins_pipe(ialu_cr_reg_imm);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11812
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11813
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11814
instruct testI_reg_mem(rFlagsReg cr, rRegI src, memory mem, immI0 zero)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11815
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11816
  match(Set cr (CmpI (AndI src (LoadI mem)) zero));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11817
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11818
  format %{ "testl   $src, $mem" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11819
  opcode(0x85);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11820
  ins_encode(REX_reg_mem(src, mem), OpcP, reg_mem(src, mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11821
  ins_pipe(ialu_cr_reg_mem);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11822
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11823
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11824
// Unsigned compare Instructions; really, same as signed except they
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11825
// produce an rFlagsRegU instead of rFlagsReg.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11826
instruct compU_rReg(rFlagsRegU cr, rRegI op1, rRegI op2)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11827
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11828
  match(Set cr (CmpU op1 op2));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11829
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11830
  format %{ "cmpl    $op1, $op2\t# unsigned" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11831
  opcode(0x3B); /* Opcode 3B /r */
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11832
  ins_encode(REX_reg_reg(op1, op2), OpcP, reg_reg(op1, op2));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11833
  ins_pipe(ialu_cr_reg_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11834
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11835
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11836
instruct compU_rReg_imm(rFlagsRegU cr, rRegI op1, immI op2)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11837
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11838
  match(Set cr (CmpU op1 op2));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11839
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11840
  format %{ "cmpl    $op1, $op2\t# unsigned" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11841
  opcode(0x81,0x07); /* Opcode 81 /7 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11842
  ins_encode(OpcSErm(op1, op2), Con8or32(op2));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11843
  ins_pipe(ialu_cr_reg_imm);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11844
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11845
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11846
instruct compU_rReg_mem(rFlagsRegU cr, rRegI op1, memory op2)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11847
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11848
  match(Set cr (CmpU op1 (LoadI op2)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11849
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11850
  ins_cost(500); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11851
  format %{ "cmpl    $op1, $op2\t# unsigned" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11852
  opcode(0x3B); /* Opcode 3B /r */
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11853
  ins_encode(REX_reg_mem(op1, op2), OpcP, reg_mem(op1, op2));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11854
  ins_pipe(ialu_cr_reg_mem);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11855
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11856
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11857
// // // Cisc-spilled version of cmpU_rReg
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11858
// //instruct compU_mem_rReg(rFlagsRegU cr, memory op1, rRegI op2)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11859
// //%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11860
// //  match(Set cr (CmpU (LoadI op1) op2));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11861
// //
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11862
// //  format %{ "CMPu   $op1,$op2" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11863
// //  ins_cost(500);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11864
// //  opcode(0x39);  /* Opcode 39 /r */
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11865
// //  ins_encode( OpcP, reg_mem( op1, op2) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11866
// //%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11867
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11868
instruct testU_reg(rFlagsRegU cr, rRegI src, immI0 zero)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11869
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11870
  match(Set cr (CmpU src zero));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11871
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11872
  format %{ "testl  $src, $src\t# unsigned" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11873
  opcode(0x85);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11874
  ins_encode(REX_reg_reg(src, src), OpcP, reg_reg(src, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11875
  ins_pipe(ialu_cr_reg_imm);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11876
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11877
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11878
instruct compP_rReg(rFlagsRegU cr, rRegP op1, rRegP op2)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11879
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11880
  match(Set cr (CmpP op1 op2));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11881
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11882
  format %{ "cmpq    $op1, $op2\t# ptr" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11883
  opcode(0x3B); /* Opcode 3B /r */
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11884
  ins_encode(REX_reg_reg_wide(op1, op2), OpcP, reg_reg(op1, op2));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11885
  ins_pipe(ialu_cr_reg_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11886
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11887
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11888
instruct compP_rReg_mem(rFlagsRegU cr, rRegP op1, memory op2)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11889
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11890
  match(Set cr (CmpP op1 (LoadP op2)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11891
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11892
  ins_cost(500); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11893
  format %{ "cmpq    $op1, $op2\t# ptr" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11894
  opcode(0x3B); /* Opcode 3B /r */
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11895
  ins_encode(REX_reg_mem_wide(op1, op2), OpcP, reg_mem(op1, op2));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11896
  ins_pipe(ialu_cr_reg_mem);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11897
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11898
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11899
// // // Cisc-spilled version of cmpP_rReg
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11900
// //instruct compP_mem_rReg(rFlagsRegU cr, memory op1, rRegP op2)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11901
// //%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11902
// //  match(Set cr (CmpP (LoadP op1) op2));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11903
// //
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11904
// //  format %{ "CMPu   $op1,$op2" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11905
// //  ins_cost(500);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11906
// //  opcode(0x39);  /* Opcode 39 /r */
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11907
// //  ins_encode( OpcP, reg_mem( op1, op2) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11908
// //%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11909
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11910
// XXX this is generalized by compP_rReg_mem???
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11911
// Compare raw pointer (used in out-of-heap check).
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11912
// Only works because non-oop pointers must be raw pointers
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11913
// and raw pointers have no anti-dependencies.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11914
instruct compP_mem_rReg(rFlagsRegU cr, rRegP op1, memory op2)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11915
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11916
  predicate(!n->in(2)->in(2)->bottom_type()->isa_oop_ptr());
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11917
  match(Set cr (CmpP op1 (LoadP op2)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11918
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11919
  format %{ "cmpq    $op1, $op2\t# raw ptr" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11920
  opcode(0x3B); /* Opcode 3B /r */
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11921
  ins_encode(REX_reg_mem_wide(op1, op2), OpcP, reg_mem(op1, op2));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11922
  ins_pipe(ialu_cr_reg_mem);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11923
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11924
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11925
// This will generate a signed flags result. This should be OK since
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11926
// any compare to a zero should be eq/neq.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11927
instruct testP_reg(rFlagsReg cr, rRegP src, immP0 zero)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11928
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11929
  match(Set cr (CmpP src zero));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11930
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11931
  format %{ "testq   $src, $src\t# ptr" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11932
  opcode(0x85);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11933
  ins_encode(REX_reg_reg_wide(src, src), OpcP, reg_reg(src, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11934
  ins_pipe(ialu_cr_reg_imm);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11935
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11936
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11937
// This will generate a signed flags result. This should be OK since
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11938
// any compare to a zero should be eq/neq.
2254
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
 11939
instruct testP_mem(rFlagsReg cr, memory op, immP0 zero)
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
 11940
%{
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
 11941
  predicate(!UseCompressedOops || (Universe::narrow_oop_base() != NULL));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11942
  match(Set cr (CmpP (LoadP op) zero));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11943
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11944
  ins_cost(500); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11945
  format %{ "testq   $op, 0xffffffffffffffff\t# ptr" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11946
  opcode(0xF7); /* Opcode F7 /0 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11947
  ins_encode(REX_mem_wide(op),
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11948
             OpcP, RM_opc_mem(0x00, op), Con_d32(0xFFFFFFFF));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11949
  ins_pipe(ialu_cr_reg_imm);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11950
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 11951
2254
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
 11952
instruct testP_mem_reg0(rFlagsReg cr, memory mem, immP0 zero)
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
 11953
%{
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
 11954
  predicate(UseCompressedOops && (Universe::narrow_oop_base() == NULL));
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
 11955
  match(Set cr (CmpP (LoadP mem) zero));
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
 11956
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
 11957
  format %{ "cmpq    R12, $mem\t# ptr (R12_heapbase==0)" %}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
 11958
  ins_encode %{
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
 11959
    __ cmpq(r12, $mem$$Address);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
 11960
  %}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
 11961
  ins_pipe(ialu_cr_reg_mem);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
 11962
%}
590
2954744d7bba 6703890: Compressed Oops: add LoadNKlass node to generate narrow oops (32-bits) compare instructions
kvn
parents: 589
diff changeset
 11963
2954744d7bba 6703890: Compressed Oops: add LoadNKlass node to generate narrow oops (32-bits) compare instructions
kvn
parents: 589
diff changeset
 11964
instruct compN_rReg(rFlagsRegU cr, rRegN op1, rRegN op2)
2954744d7bba 6703890: Compressed Oops: add LoadNKlass node to generate narrow oops (32-bits) compare instructions
kvn
parents: 589
diff changeset
 11965
%{
2954744d7bba 6703890: Compressed Oops: add LoadNKlass node to generate narrow oops (32-bits) compare instructions
kvn
parents: 589
diff changeset
 11966
  match(Set cr (CmpN op1 op2));
2954744d7bba 6703890: Compressed Oops: add LoadNKlass node to generate narrow oops (32-bits) compare instructions
kvn
parents: 589
diff changeset
 11967
2954744d7bba 6703890: Compressed Oops: add LoadNKlass node to generate narrow oops (32-bits) compare instructions
kvn
parents: 589
diff changeset
 11968
  format %{ "cmpl    $op1, $op2\t# compressed ptr" %}
2254
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
 11969
  ins_encode %{ __ cmpl($op1$$Register, $op2$$Register); %}
590
2954744d7bba 6703890: Compressed Oops: add LoadNKlass node to generate narrow oops (32-bits) compare instructions
kvn
parents: 589
diff changeset
 11970
  ins_pipe(ialu_cr_reg_reg);
2954744d7bba 6703890: Compressed Oops: add LoadNKlass node to generate narrow oops (32-bits) compare instructions
kvn
parents: 589
diff changeset
 11971
%}
2954744d7bba 6703890: Compressed Oops: add LoadNKlass node to generate narrow oops (32-bits) compare instructions
kvn
parents: 589
diff changeset
 11972
2954744d7bba 6703890: Compressed Oops: add LoadNKlass node to generate narrow oops (32-bits) compare instructions
kvn
parents: 589
diff changeset
 11973
instruct compN_rReg_mem(rFlagsRegU cr, rRegN src, memory mem)
2954744d7bba 6703890: Compressed Oops: add LoadNKlass node to generate narrow oops (32-bits) compare instructions
kvn
parents: 589
diff changeset
 11974
%{
2954744d7bba 6703890: Compressed Oops: add LoadNKlass node to generate narrow oops (32-bits) compare instructions
kvn
parents: 589
diff changeset
 11975
  match(Set cr (CmpN src (LoadN mem)));
2954744d7bba 6703890: Compressed Oops: add LoadNKlass node to generate narrow oops (32-bits) compare instructions
kvn
parents: 589
diff changeset
 11976
2254
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
 11977
  format %{ "cmpl    $src, $mem\t# compressed ptr" %}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
 11978
  ins_encode %{
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
 11979
    __ cmpl($src$$Register, $mem$$Address);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
 11980
  %}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
 11981
  ins_pipe(ialu_cr_reg_mem);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
 11982
%}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
 11983
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
 11984
instruct compN_rReg_imm(rFlagsRegU cr, rRegN op1, immN op2) %{
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
 11985
  match(Set cr (CmpN op1 op2));
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
 11986
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
 11987
  format %{ "cmpl    $op1, $op2\t# compressed ptr" %}
590
2954744d7bba 6703890: Compressed Oops: add LoadNKlass node to generate narrow oops (32-bits) compare instructions
kvn
parents: 589
diff changeset
 11988
  ins_encode %{
2254
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
 11989
    __ cmp_narrow_oop($op1$$Register, (jobject)$op2$$constant);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
 11990
  %}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
 11991
  ins_pipe(ialu_cr_reg_imm);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
 11992
%}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
 11993
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
 11994
instruct compN_mem_imm(rFlagsRegU cr, memory mem, immN src)
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
 11995
%{
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
 11996
  match(Set cr (CmpN src (LoadN mem)));
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
 11997
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
 11998
  format %{ "cmpl    $mem, $src\t# compressed ptr" %}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
 11999
  ins_encode %{
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
 12000
    __ cmp_narrow_oop($mem$$Address, (jobject)$src$$constant);
590
2954744d7bba 6703890: Compressed Oops: add LoadNKlass node to generate narrow oops (32-bits) compare instructions
kvn
parents: 589
diff changeset
 12001
  %}
2954744d7bba 6703890: Compressed Oops: add LoadNKlass node to generate narrow oops (32-bits) compare instructions
kvn
parents: 589
diff changeset
 12002
  ins_pipe(ialu_cr_reg_mem);
2954744d7bba 6703890: Compressed Oops: add LoadNKlass node to generate narrow oops (32-bits) compare instructions
kvn
parents: 589
diff changeset
 12003
%}
2954744d7bba 6703890: Compressed Oops: add LoadNKlass node to generate narrow oops (32-bits) compare instructions
kvn
parents: 589
diff changeset
 12004
360
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
 12005
instruct testN_reg(rFlagsReg cr, rRegN src, immN0 zero) %{
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
 12006
  match(Set cr (CmpN src zero));
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
 12007
590
2954744d7bba 6703890: Compressed Oops: add LoadNKlass node to generate narrow oops (32-bits) compare instructions
kvn
parents: 589
diff changeset
 12008
  format %{ "testl   $src, $src\t# compressed ptr" %}
360
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
 12009
  ins_encode %{ __ testl($src$$Register, $src$$Register); %}
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
 12010
  ins_pipe(ialu_cr_reg_imm);
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
 12011
%}
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 244
diff changeset
 12012
2254
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
 12013
instruct testN_mem(rFlagsReg cr, memory mem, immN0 zero)
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
 12014
%{
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
 12015
  predicate(Universe::narrow_oop_base() != NULL);
590
2954744d7bba 6703890: Compressed Oops: add LoadNKlass node to generate narrow oops (32-bits) compare instructions
kvn
parents: 589
diff changeset
 12016
  match(Set cr (CmpN (LoadN mem) zero));
2954744d7bba 6703890: Compressed Oops: add LoadNKlass node to generate narrow oops (32-bits) compare instructions
kvn
parents: 589
diff changeset
 12017
2954744d7bba 6703890: Compressed Oops: add LoadNKlass node to generate narrow oops (32-bits) compare instructions
kvn
parents: 589
diff changeset
 12018
  ins_cost(500); // XXX
2954744d7bba 6703890: Compressed Oops: add LoadNKlass node to generate narrow oops (32-bits) compare instructions
kvn
parents: 589
diff changeset
 12019
  format %{ "testl   $mem, 0xffffffff\t# compressed ptr" %}
2954744d7bba 6703890: Compressed Oops: add LoadNKlass node to generate narrow oops (32-bits) compare instructions
kvn
parents: 589
diff changeset
 12020
  ins_encode %{
2254
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
 12021
    __ cmpl($mem$$Address, (int)0xFFFFFFFF);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
 12022
  %}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
 12023
  ins_pipe(ialu_cr_reg_mem);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
 12024
%}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
 12025
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
 12026
instruct testN_mem_reg0(rFlagsReg cr, memory mem, immN0 zero)
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
 12027
%{
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
 12028
  predicate(Universe::narrow_oop_base() == NULL);
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
 12029
  match(Set cr (CmpN (LoadN mem) zero));
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
 12030
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
 12031
  format %{ "cmpl    R12, $mem\t# compressed ptr (R12_heapbase==0)" %}
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
 12032
  ins_encode %{
f13dda645a4b 6791178: Specialize for zero as the compressed oop vm heap base
kvn
parents: 2150
diff changeset
 12033
    __ cmpl(r12, $mem$$Address);
590
2954744d7bba 6703890: Compressed Oops: add LoadNKlass node to generate narrow oops (32-bits) compare instructions
kvn
parents: 589
diff changeset
 12034
  %}
2954744d7bba 6703890: Compressed Oops: add LoadNKlass node to generate narrow oops (32-bits) compare instructions
kvn
parents: 589
diff changeset
 12035
  ins_pipe(ialu_cr_reg_mem);
2954744d7bba 6703890: Compressed Oops: add LoadNKlass node to generate narrow oops (32-bits) compare instructions
kvn
parents: 589
diff changeset
 12036
%}
2954744d7bba 6703890: Compressed Oops: add LoadNKlass node to generate narrow oops (32-bits) compare instructions
kvn
parents: 589
diff changeset
 12037
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12038
// Yanked all unsigned pointer compare operations.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12039
// Pointer compares are done with CmpP which is already unsigned.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12040
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12041
instruct compL_rReg(rFlagsReg cr, rRegL op1, rRegL op2)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12042
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12043
  match(Set cr (CmpL op1 op2));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12044
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12045
  format %{ "cmpq    $op1, $op2" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12046
  opcode(0x3B);  /* Opcode 3B /r */
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12047
  ins_encode(REX_reg_reg_wide(op1, op2), OpcP, reg_reg(op1, op2));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12048
  ins_pipe(ialu_cr_reg_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12049
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12050
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12051
instruct compL_rReg_imm(rFlagsReg cr, rRegL op1, immL32 op2)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12052
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12053
  match(Set cr (CmpL op1 op2));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12054
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12055
  format %{ "cmpq    $op1, $op2" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12056
  opcode(0x81, 0x07); /* Opcode 81 /7 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12057
  ins_encode(OpcSErm_wide(op1, op2), Con8or32(op2));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12058
  ins_pipe(ialu_cr_reg_imm);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12059
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12060
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12061
instruct compL_rReg_mem(rFlagsReg cr, rRegL op1, memory op2)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12062
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12063
  match(Set cr (CmpL op1 (LoadL op2)));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12064
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12065
  format %{ "cmpq    $op1, $op2" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12066
  opcode(0x3B); /* Opcode 3B /r */
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12067
  ins_encode(REX_reg_mem_wide(op1, op2), OpcP, reg_mem(op1, op2));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12068
  ins_pipe(ialu_cr_reg_mem);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12069
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12070
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12071
instruct testL_reg(rFlagsReg cr, rRegL src, immL0 zero)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12072
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12073
  match(Set cr (CmpL src zero));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12074
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12075
  format %{ "testq   $src, $src" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12076
  opcode(0x85);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12077
  ins_encode(REX_reg_reg_wide(src, src), OpcP, reg_reg(src, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12078
  ins_pipe(ialu_cr_reg_imm);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12079
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12080
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12081
instruct testL_reg_imm(rFlagsReg cr, rRegL src, immL32 con, immL0 zero)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12082
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12083
  match(Set cr (CmpL (AndL src con) zero));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12084
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12085
  format %{ "testq   $src, $con\t# long" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12086
  opcode(0xF7, 0x00);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12087
  ins_encode(REX_reg_wide(src), OpcP, reg_opc(src), Con32(con));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12088
  ins_pipe(ialu_cr_reg_imm);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12089
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12090
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12091
instruct testL_reg_mem(rFlagsReg cr, rRegL src, memory mem, immL0 zero)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12092
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12093
  match(Set cr (CmpL (AndL src (LoadL mem)) zero));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12094
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12095
  format %{ "testq   $src, $mem" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12096
  opcode(0x85);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12097
  ins_encode(REX_reg_mem_wide(src, mem), OpcP, reg_mem(src, mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12098
  ins_pipe(ialu_cr_reg_mem);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12099
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12100
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12101
// Manifest a CmpL result in an integer register.  Very painful.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12102
// This is the test to avoid.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12103
instruct cmpL3_reg_reg(rRegI dst, rRegL src1, rRegL src2, rFlagsReg flags)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12104
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12105
  match(Set dst (CmpL3 src1 src2));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12106
  effect(KILL flags);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12107
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12108
  ins_cost(275); // XXX
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12109
  format %{ "cmpq    $src1, $src2\t# CmpL3\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12110
            "movl    $dst, -1\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12111
            "jl,s    done\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12112
            "setne   $dst\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12113
            "movzbl  $dst, $dst\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12114
    "done:" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12115
  ins_encode(cmpl3_flag(src1, src2, dst));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12116
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12117
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12118
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12119
//----------Max and Min--------------------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12120
// Min Instructions
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12121
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12122
instruct cmovI_reg_g(rRegI dst, rRegI src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12123
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12124
  effect(USE_DEF dst, USE src, USE cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12125
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12126
  format %{ "cmovlgt $dst, $src\t# min" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12127
  opcode(0x0F, 0x4F);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12128
  ins_encode(REX_reg_reg(dst, src), OpcP, OpcS, reg_reg(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12129
  ins_pipe(pipe_cmov_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12130
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12131
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12132
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12133
instruct minI_rReg(rRegI dst, rRegI src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12134
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12135
  match(Set dst (MinI dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12136
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12137
  ins_cost(200);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12138
  expand %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12139
    rFlagsReg cr;
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12140
    compI_rReg(cr, dst, src);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12141
    cmovI_reg_g(dst, src, cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12142
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12143
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12144
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12145
instruct cmovI_reg_l(rRegI dst, rRegI src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12146
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12147
  effect(USE_DEF dst, USE src, USE cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12148
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12149
  format %{ "cmovllt $dst, $src\t# max" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12150
  opcode(0x0F, 0x4C);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12151
  ins_encode(REX_reg_reg(dst, src), OpcP, OpcS, reg_reg(dst, src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12152
  ins_pipe(pipe_cmov_reg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12153
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12154
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12155
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12156
instruct maxI_rReg(rRegI dst, rRegI src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12157
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12158
  match(Set dst (MaxI dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12159
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12160
  ins_cost(200);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12161
  expand %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12162
    rFlagsReg cr;
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12163
    compI_rReg(cr, dst, src);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12164
    cmovI_reg_l(dst, src, cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12165
  %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12166
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12167
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12168
// ============================================================================
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12169
// Branch Instructions
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12170
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12171
// Jump Direct - Label defines a relative address from JMP+1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12172
instruct jmpDir(label labl)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12173
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12174
  match(Goto);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12175
  effect(USE labl);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12176
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12177
  ins_cost(300);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12178
  format %{ "jmp     $labl" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12179
  size(5);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12180
  opcode(0xE9);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12181
  ins_encode(OpcP, Lbl(labl));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12182
  ins_pipe(pipe_jmp);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12183
  ins_pc_relative(1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12184
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12185
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12186
// Jump Direct Conditional - Label defines a relative address from Jcc+1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12187
instruct jmpCon(cmpOp cop, rFlagsReg cr, label labl)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12188
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12189
  match(If cop cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12190
  effect(USE labl);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12191
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12192
  ins_cost(300);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12193
  format %{ "j$cop     $labl" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12194
  size(6);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12195
  opcode(0x0F, 0x80);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12196
  ins_encode(Jcc(cop, labl));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12197
  ins_pipe(pipe_jcc);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12198
  ins_pc_relative(1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12199
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12200
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12201
// Jump Direct Conditional - Label defines a relative address from Jcc+1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12202
instruct jmpLoopEnd(cmpOp cop, rFlagsReg cr, label labl)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12203
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12204
  match(CountedLoopEnd cop cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12205
  effect(USE labl);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12206
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12207
  ins_cost(300);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12208
  format %{ "j$cop     $labl\t# loop end" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12209
  size(6);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12210
  opcode(0x0F, 0x80);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12211
  ins_encode(Jcc(cop, labl));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12212
  ins_pipe(pipe_jcc);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12213
  ins_pc_relative(1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12214
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12215
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12216
// Jump Direct Conditional - Label defines a relative address from Jcc+1
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12217
instruct jmpLoopEndU(cmpOpU cop, rFlagsRegU cmp, label labl) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12218
  match(CountedLoopEnd cop cmp);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12219
  effect(USE labl);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12220
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12221
  ins_cost(300);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12222
  format %{ "j$cop,u   $labl\t# loop end" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12223
  size(6);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12224
  opcode(0x0F, 0x80);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12225
  ins_encode(Jcc(cop, labl));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12226
  ins_pipe(pipe_jcc);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12227
  ins_pc_relative(1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12228
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12229
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12230
instruct jmpLoopEndUCF(cmpOpUCF cop, rFlagsRegUCF 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
 12231
  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
 12232
  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
 12233
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12234
  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
 12235
  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
 12236
  size(6);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12237
  opcode(0x0F, 0x80);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12238
  ins_encode(Jcc(cop, labl));
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12239
  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
 12240
  ins_pc_relative(1);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12241
%}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12242
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12243
// Jump Direct Conditional - using unsigned comparison
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12244
instruct jmpConU(cmpOpU cop, rFlagsRegU cmp, label labl) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12245
  match(If cop cmp);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12246
  effect(USE labl);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12247
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12248
  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
 12249
  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
 12250
  size(6);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12251
  opcode(0x0F, 0x80);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12252
  ins_encode(Jcc(cop, labl));
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12253
  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
 12254
  ins_pc_relative(1);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12255
%}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12256
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12257
instruct jmpConUCF(cmpOpUCF cop, rFlagsRegUCF 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
 12258
  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
 12259
  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
 12260
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12261
  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
 12262
  format %{ "j$cop,u  $labl" %}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12263
  size(6);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12264
  opcode(0x0F, 0x80);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12265
  ins_encode(Jcc(cop, labl));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12266
  ins_pipe(pipe_jcc);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12267
  ins_pc_relative(1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12268
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12269
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12270
instruct jmpConUCF2(cmpOpUCF2 cop, rFlagsRegUCF 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
 12271
  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
 12272
  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
 12273
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12274
  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
 12275
  format %{ $$template
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12276
    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
 12277
      $$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
 12278
      $$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
 12279
    } else {
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12280
      $$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
 12281
      $$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
 12282
      $$emit$$"done:"
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12283
    }
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12284
  %}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12285
  size(12);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12286
  opcode(0x0F, 0x80);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12287
  ins_encode %{
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12288
    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
 12289
    $$$emit8$primary;
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12290
    emit_cc(cbuf, $secondary, Assembler::parity);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12291
    int parity_disp = -1;
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12292
    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
 12293
       // the two jumps 6 bytes apart so the jump distances are too
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12294
       parity_disp = l ? (l->loc_pos() - (cbuf.code_size() + 4)) : 0;
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12295
    } else if ($cop$$cmpcode == Assembler::equal) {
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12296
       parity_disp = 6;
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12297
    } else {
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12298
       ShouldNotReachHere();
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12299
    }
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12300
    emit_d32(cbuf, parity_disp);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12301
    $$$emit8$primary;
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12302
    emit_cc(cbuf, $secondary, $cop$$cmpcode);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12303
    int disp = l ? (l->loc_pos() - (cbuf.code_size() + 4)) : 0;
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12304
    emit_d32(cbuf, disp);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12305
  %}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12306
  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
 12307
  ins_pc_relative(1);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12308
%}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12309
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12310
// ============================================================================
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12311
// The 2nd slow-half of a subtype check.  Scan the subklass's 2ndary
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12312
// superklass array for an instance of the superklass.  Set a hidden
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12313
// internal cache on a hit (cache is checked with exposed code in
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12314
// gen_subtype_check()).  Return NZ for a miss or zero for a hit.  The
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12315
// encoding ALSO sets flags.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12316
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12317
instruct partialSubtypeCheck(rdi_RegP result,
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12318
                             rsi_RegP sub, rax_RegP super, rcx_RegI rcx,
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12319
                             rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12320
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12321
  match(Set result (PartialSubtypeCheck sub super));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12322
  effect(KILL rcx, KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12323
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12324
  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
 12325
  format %{ "movq    rdi, [$sub + (sizeof(oopDesc) + Klass::secondary_supers_offset_in_bytes())]\n\t"
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12326
            "movl    rcx, [rdi + arrayOopDesc::length_offset_in_bytes()]\t# length to scan\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12327
            "addq    rdi, arrayOopDex::base_offset_in_bytes(T_OBJECT)\t# Skip to start of data; set NZ in case count is zero\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12328
            "repne   scasq\t# Scan *rdi++ for a match with rax while rcx--\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12329
            "jne,s   miss\t\t# Missed: rdi not-zero\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12330
            "movq    [$sub + (sizeof(oopDesc) + Klass::secondary_super_cache_offset_in_bytes())], $super\t# Hit: update cache\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12331
            "xorq    $result, $result\t\t Hit: rdi zero\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12332
    "miss:\t" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12333
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12334
  opcode(0x1); // Force a XOR of RDI
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12335
  ins_encode(enc_PartialSubtypeCheck());
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12336
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12337
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12338
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12339
instruct partialSubtypeCheck_vs_Zero(rFlagsReg cr,
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12340
                                     rsi_RegP sub, rax_RegP super, rcx_RegI rcx,
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12341
                                     immP0 zero,
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12342
                                     rdi_RegP result)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12343
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12344
  match(Set cr (CmpP (PartialSubtypeCheck sub super) zero));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12345
  effect(KILL rcx, KILL result);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12346
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12347
  ins_cost(1000);
2256
82d4e10b7c6b 6813212: factor duplicated assembly code for general subclass check (for 6655638)
jrose
parents: 2255
diff changeset
 12348
  format %{ "movq    rdi, [$sub + (sizeof(oopDesc) + Klass::secondary_supers_offset_in_bytes())]\n\t"
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12349
            "movl    rcx, [rdi + arrayOopDesc::length_offset_in_bytes()]\t# length to scan\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12350
            "addq    rdi, arrayOopDex::base_offset_in_bytes(T_OBJECT)\t# Skip to start of data; set NZ in case count is zero\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12351
            "repne   scasq\t# Scan *rdi++ for a match with rax while cx-- != 0\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12352
            "jne,s   miss\t\t# Missed: flags nz\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12353
            "movq    [$sub + (sizeof(oopDesc) + Klass::secondary_super_cache_offset_in_bytes())], $super\t# Hit: update cache\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12354
    "miss:\t" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12355
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12356
  opcode(0x0); // No need to XOR RDI
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12357
  ins_encode(enc_PartialSubtypeCheck());
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12358
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12359
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12360
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12361
// ============================================================================
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12362
// Branch Instructions -- short offset versions
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12363
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12364
// These instructions are used to replace jumps of a long offset (the default
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12365
// match) with jumps of a shorter offset.  These instructions are all tagged
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12366
// with the ins_short_branch attribute, which causes the ADLC to suppress the
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12367
// match rules in general matching.  Instead, the ADLC generates a conversion
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12368
// method in the MachNode which can be used to do in-place replacement of the
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12369
// long variant with the shorter variant.  The compiler will determine if a
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12370
// branch can be taken by the is_short_branch_offset() predicate in the machine
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12371
// specific code section of the file.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12372
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12373
// Jump Direct - Label defines a relative address from JMP+1
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12374
instruct jmpDir_short(label labl) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12375
  match(Goto);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12376
  effect(USE labl);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12377
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12378
  ins_cost(300);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12379
  format %{ "jmp,s   $labl" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12380
  size(2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12381
  opcode(0xEB);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12382
  ins_encode(OpcP, LblShort(labl));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12383
  ins_pipe(pipe_jmp);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12384
  ins_pc_relative(1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12385
  ins_short_branch(1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12386
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12387
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12388
// Jump Direct Conditional - Label defines a relative address from Jcc+1
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12389
instruct jmpCon_short(cmpOp cop, rFlagsReg cr, label labl) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12390
  match(If cop cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12391
  effect(USE labl);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12392
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12393
  ins_cost(300);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12394
  format %{ "j$cop,s   $labl" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12395
  size(2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12396
  opcode(0x70);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12397
  ins_encode(JccShort(cop, labl));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12398
  ins_pipe(pipe_jcc);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12399
  ins_pc_relative(1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12400
  ins_short_branch(1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12401
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12402
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12403
// Jump Direct Conditional - Label defines a relative address from Jcc+1
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12404
instruct jmpLoopEnd_short(cmpOp cop, rFlagsReg cr, label labl) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12405
  match(CountedLoopEnd cop cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12406
  effect(USE labl);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12407
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12408
  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
 12409
  format %{ "j$cop,s   $labl\t# loop end" %}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12410
  size(2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12411
  opcode(0x70);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12412
  ins_encode(JccShort(cop, labl));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12413
  ins_pipe(pipe_jcc);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12414
  ins_pc_relative(1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12415
  ins_short_branch(1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12416
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12417
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12418
// Jump Direct Conditional - Label defines a relative address from Jcc+1
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12419
instruct jmpLoopEndU_short(cmpOpU cop, rFlagsRegU 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
 12420
  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
 12421
  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
 12422
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12423
  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
 12424
  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
 12425
  size(2);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12426
  opcode(0x70);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12427
  ins_encode(JccShort(cop, labl));
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12428
  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
 12429
  ins_pc_relative(1);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12430
  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
 12431
%}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12432
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12433
instruct jmpLoopEndUCF_short(cmpOpUCF cop, rFlagsRegUCF cmp, label labl) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12434
  match(CountedLoopEnd cop cmp);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12435
  effect(USE labl);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12436
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12437
  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
 12438
  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
 12439
  size(2);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12440
  opcode(0x70);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12441
  ins_encode(JccShort(cop, labl));
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12442
  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
 12443
  ins_pc_relative(1);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12444
  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
 12445
%}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12446
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12447
// Jump Direct Conditional - using unsigned comparison
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12448
instruct jmpConU_short(cmpOpU cop, rFlagsRegU 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
 12449
  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
 12450
  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
 12451
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12452
  ins_cost(300);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12453
  format %{ "j$cop,us  $labl" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12454
  size(2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12455
  opcode(0x70);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12456
  ins_encode(JccShort(cop, labl));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12457
  ins_pipe(pipe_jcc);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12458
  ins_pc_relative(1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12459
  ins_short_branch(1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12460
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12461
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12462
instruct jmpConUCF_short(cmpOpUCF cop, rFlagsRegUCF cmp, label labl) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12463
  match(If cop cmp);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12464
  effect(USE labl);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12465
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12466
  ins_cost(300);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12467
  format %{ "j$cop,us  $labl" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12468
  size(2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12469
  opcode(0x70);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12470
  ins_encode(JccShort(cop, labl));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12471
  ins_pipe(pipe_jcc);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12472
  ins_pc_relative(1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12473
  ins_short_branch(1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12474
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12475
1495
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12476
instruct jmpConUCF2_short(cmpOpUCF2 cop, rFlagsRegUCF 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
 12477
  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
 12478
  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
 12479
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12480
  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
 12481
  format %{ $$template
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12482
    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
 12483
      $$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
 12484
      $$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
 12485
    } else {
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12486
      $$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
 12487
      $$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
 12488
      $$emit$$"done:"
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12489
    }
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12490
  %}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12491
  size(4);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12492
  opcode(0x70);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12493
  ins_encode %{
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12494
    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
 12495
    emit_cc(cbuf, $primary, Assembler::parity);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12496
    int parity_disp = -1;
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12497
    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
 12498
      parity_disp = l ? (l->loc_pos() - (cbuf.code_size() + 1)) : 0;
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12499
    } else if ($cop$$cmpcode == Assembler::equal) {
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12500
      parity_disp = 2;
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12501
    } else {
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12502
      ShouldNotReachHere();
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12503
    }
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12504
    emit_d8(cbuf, parity_disp);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12505
    emit_cc(cbuf, $primary, $cop$$cmpcode);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12506
    int disp = l ? (l->loc_pos() - (cbuf.code_size() + 1)) : 0;
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12507
    emit_d8(cbuf, disp);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12508
    assert(-128 <= disp && disp <= 127, "Displacement too large for short jmp");
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12509
    assert(-128 <= parity_disp && parity_disp <= 127, "Displacement too large for short jmp");
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12510
  %}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12511
  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
 12512
  ins_pc_relative(1);
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12513
  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
 12514
%}
128fe18951ed 6754519: don't emit flag fixup for NaN when condition being tested doesn't need it
never
parents: 1435
diff changeset
 12515
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12516
// ============================================================================
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12517
// inlined locking and unlocking
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12518
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12519
instruct cmpFastLock(rFlagsReg cr,
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12520
                     rRegP object, rRegP box, rax_RegI tmp, rRegP scr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12521
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12522
  match(Set cr (FastLock object box));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12523
  effect(TEMP tmp, TEMP scr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12524
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12525
  ins_cost(300);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12526
  format %{ "fastlock $object,$box,$tmp,$scr" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12527
  ins_encode(Fast_Lock(object, box, tmp, scr));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12528
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12529
  ins_pc_relative(1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12530
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12531
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12532
instruct cmpFastUnlock(rFlagsReg cr,
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12533
                       rRegP object, rax_RegP box, rRegP tmp)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12534
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12535
  match(Set cr (FastUnlock object box));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12536
  effect(TEMP tmp);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12537
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12538
  ins_cost(300);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12539
  format %{ "fastunlock $object, $box, $tmp" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12540
  ins_encode(Fast_Unlock(object, box, tmp));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12541
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12542
  ins_pc_relative(1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12543
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12544
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12545
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12546
// ============================================================================
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12547
// Safepoint Instructions
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12548
instruct safePoint_poll(rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12549
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12550
  match(SafePoint);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12551
  effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12552
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12553
  format %{ "testl   rax, [rip + #offset_to_poll_page]\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12554
            "# Safepoint: poll for GC" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12555
  size(6); // Opcode + ModRM + Disp32 == 6 bytes
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12556
  ins_cost(125);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12557
  ins_encode(enc_safepoint_poll);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12558
  ins_pipe(ialu_reg_mem);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12559
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12560
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12561
// ============================================================================
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12562
// Procedure Call/Return Instructions
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12563
// Call Java Static Instruction
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12564
// Note: If this code changes, the corresponding ret_addr_offset() and
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12565
//       compute_padding() functions will have to be adjusted.
4566
b363f6ef4068 6829187: compiler optimizations required for JSR 292
twisti
parents: 3908
diff changeset
 12566
instruct CallStaticJavaDirect(method meth) %{
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12567
  match(CallStaticJava);
4566
b363f6ef4068 6829187: compiler optimizations required for JSR 292
twisti
parents: 3908
diff changeset
 12568
  predicate(!((CallStaticJavaNode*) n)->is_method_handle_invoke());
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12569
  effect(USE meth);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12570
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12571
  ins_cost(300);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12572
  format %{ "call,static " %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12573
  opcode(0xE8); /* E8 cd */
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12574
  ins_encode(Java_Static_Call(meth), call_epilog);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12575
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12576
  ins_pc_relative(1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12577
  ins_alignment(4);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12578
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12579
4566
b363f6ef4068 6829187: compiler optimizations required for JSR 292
twisti
parents: 3908
diff changeset
 12580
// Call Java Static Instruction (method handle version)
b363f6ef4068 6829187: compiler optimizations required for JSR 292
twisti
parents: 3908
diff changeset
 12581
// Note: If this code changes, the corresponding ret_addr_offset() and
b363f6ef4068 6829187: compiler optimizations required for JSR 292
twisti
parents: 3908
diff changeset
 12582
//       compute_padding() functions will have to be adjusted.
b363f6ef4068 6829187: compiler optimizations required for JSR 292
twisti
parents: 3908
diff changeset
 12583
instruct CallStaticJavaHandle(method meth, rbp_RegP rbp) %{
b363f6ef4068 6829187: compiler optimizations required for JSR 292
twisti
parents: 3908
diff changeset
 12584
  match(CallStaticJava);
b363f6ef4068 6829187: compiler optimizations required for JSR 292
twisti
parents: 3908
diff changeset
 12585
  predicate(((CallStaticJavaNode*) n)->is_method_handle_invoke());
b363f6ef4068 6829187: compiler optimizations required for JSR 292
twisti
parents: 3908
diff changeset
 12586
  effect(USE meth);
b363f6ef4068 6829187: compiler optimizations required for JSR 292
twisti
parents: 3908
diff changeset
 12587
  // RBP is saved by all callees (for interpreter stack correction).
b363f6ef4068 6829187: compiler optimizations required for JSR 292
twisti
parents: 3908
diff changeset
 12588
  // We use it here for a similar purpose, in {preserve,restore}_SP.
b363f6ef4068 6829187: compiler optimizations required for JSR 292
twisti
parents: 3908
diff changeset
 12589
b363f6ef4068 6829187: compiler optimizations required for JSR 292
twisti
parents: 3908
diff changeset
 12590
  ins_cost(300);
b363f6ef4068 6829187: compiler optimizations required for JSR 292
twisti
parents: 3908
diff changeset
 12591
  format %{ "call,static/MethodHandle " %}
b363f6ef4068 6829187: compiler optimizations required for JSR 292
twisti
parents: 3908
diff changeset
 12592
  opcode(0xE8); /* E8 cd */
b363f6ef4068 6829187: compiler optimizations required for JSR 292
twisti
parents: 3908
diff changeset
 12593
  ins_encode(preserve_SP,
b363f6ef4068 6829187: compiler optimizations required for JSR 292
twisti
parents: 3908
diff changeset
 12594
             Java_Static_Call(meth),
b363f6ef4068 6829187: compiler optimizations required for JSR 292
twisti
parents: 3908
diff changeset
 12595
             restore_SP,
b363f6ef4068 6829187: compiler optimizations required for JSR 292
twisti
parents: 3908
diff changeset
 12596
             call_epilog);
b363f6ef4068 6829187: compiler optimizations required for JSR 292
twisti
parents: 3908
diff changeset
 12597
  ins_pipe(pipe_slow);
b363f6ef4068 6829187: compiler optimizations required for JSR 292
twisti
parents: 3908
diff changeset
 12598
  ins_pc_relative(1);
b363f6ef4068 6829187: compiler optimizations required for JSR 292
twisti
parents: 3908
diff changeset
 12599
  ins_alignment(4);
b363f6ef4068 6829187: compiler optimizations required for JSR 292
twisti
parents: 3908
diff changeset
 12600
%}
b363f6ef4068 6829187: compiler optimizations required for JSR 292
twisti
parents: 3908
diff changeset
 12601
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12602
// Call Java Dynamic Instruction
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12603
// Note: If this code changes, the corresponding ret_addr_offset() and
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12604
//       compute_padding() functions will have to be adjusted.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12605
instruct CallDynamicJavaDirect(method meth)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12606
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12607
  match(CallDynamicJava);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12608
  effect(USE meth);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12609
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12610
  ins_cost(300);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12611
  format %{ "movq    rax, #Universe::non_oop_word()\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12612
            "call,dynamic " %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12613
  opcode(0xE8); /* E8 cd */
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12614
  ins_encode(Java_Dynamic_Call(meth), call_epilog);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12615
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12616
  ins_pc_relative(1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12617
  ins_alignment(4);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12618
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12619
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12620
// Call Runtime Instruction
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12621
instruct CallRuntimeDirect(method meth)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12622
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12623
  match(CallRuntime);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12624
  effect(USE meth);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12625
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12626
  ins_cost(300);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12627
  format %{ "call,runtime " %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12628
  opcode(0xE8); /* E8 cd */
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12629
  ins_encode(Java_To_Runtime(meth));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12630
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12631
  ins_pc_relative(1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12632
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12633
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12634
// Call runtime without safepoint
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12635
instruct CallLeafDirect(method meth)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12636
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12637
  match(CallLeaf);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12638
  effect(USE meth);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12639
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12640
  ins_cost(300);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12641
  format %{ "call_leaf,runtime " %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12642
  opcode(0xE8); /* E8 cd */
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12643
  ins_encode(Java_To_Runtime(meth));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12644
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12645
  ins_pc_relative(1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12646
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12647
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12648
// Call runtime without safepoint
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12649
instruct CallLeafNoFPDirect(method meth)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12650
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12651
  match(CallLeafNoFP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12652
  effect(USE meth);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12653
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12654
  ins_cost(300);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12655
  format %{ "call_leaf_nofp,runtime " %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12656
  opcode(0xE8); /* E8 cd */
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12657
  ins_encode(Java_To_Runtime(meth));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12658
  ins_pipe(pipe_slow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12659
  ins_pc_relative(1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12660
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12661
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12662
// Return Instruction
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12663
// Remove the return address & jump to it.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12664
// Notice: We always emit a nop after a ret to make sure there is room
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12665
// for safepoint patching
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12666
instruct Ret()
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12667
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12668
  match(Return);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12669
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12670
  format %{ "ret" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12671
  opcode(0xC3);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12672
  ins_encode(OpcP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12673
  ins_pipe(pipe_jmp);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12674
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12675
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12676
// Tail Call; Jump from runtime stub to Java code.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12677
// Also known as an 'interprocedural jump'.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12678
// Target of jump will eventually return to caller.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12679
// TailJump below removes the return address.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12680
instruct TailCalljmpInd(no_rbp_RegP jump_target, rbx_RegP method_oop)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12681
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12682
  match(TailCall jump_target method_oop);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12683
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12684
  ins_cost(300);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12685
  format %{ "jmp     $jump_target\t# rbx holds method oop" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12686
  opcode(0xFF, 0x4); /* Opcode FF /4 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12687
  ins_encode(REX_reg(jump_target), OpcP, reg_opc(jump_target));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12688
  ins_pipe(pipe_jmp);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12689
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12690
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12691
// Tail Jump; remove the return address; jump to target.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12692
// TailCall above leaves the return address around.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12693
instruct tailjmpInd(no_rbp_RegP jump_target, rax_RegP ex_oop)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12694
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12695
  match(TailJump jump_target ex_oop);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12696
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12697
  ins_cost(300);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12698
  format %{ "popq    rdx\t# pop return address\n\t"
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12699
            "jmp     $jump_target" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12700
  opcode(0xFF, 0x4); /* Opcode FF /4 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12701
  ins_encode(Opcode(0x5a), // popq rdx
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12702
             REX_reg(jump_target), OpcP, reg_opc(jump_target));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12703
  ins_pipe(pipe_jmp);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12704
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12705
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12706
// Create exception oop: created by stack-crawling runtime code.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12707
// Created exception is now available to this handler, and is setup
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12708
// just prior to jumping to this handler.  No code emitted.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12709
instruct CreateException(rax_RegP ex_oop)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12710
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12711
  match(Set ex_oop (CreateEx));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12712
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12713
  size(0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12714
  // use the following format syntax
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12715
  format %{ "# exception oop is in rax; no code emitted" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12716
  ins_encode();
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12717
  ins_pipe(empty);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12718
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12719
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12720
// Rethrow exception:
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12721
// The exception oop will come in the first argument position.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12722
// Then JUMP (not call) to the rethrow stub code.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12723
instruct RethrowException()
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12724
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12725
  match(Rethrow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12726
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12727
  // use the following format syntax
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12728
  format %{ "jmp     rethrow_stub" %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12729
  ins_encode(enc_rethrow);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12730
  ins_pipe(pipe_jmp);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12731
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12732
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12733
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12734
//----------PEEPHOLE RULES-----------------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12735
// These must follow all instruction definitions as they use the names
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12736
// defined in the instructions definitions.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12737
//
2131
98f9cef66a34 6810672: Comment typos
twisti
parents: 2033
diff changeset
 12738
// peepmatch ( root_instr_name [preceding_instruction]* );
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12739
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12740
// peepconstraint %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12741
// (instruction_number.operand_name relational_op instruction_number.operand_name
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12742
//  [, ...] );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12743
// // instruction numbers are zero-based using left to right order in peepmatch
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12744
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12745
// peepreplace ( instr_name  ( [instruction_number.operand_name]* ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12746
// // provide an instruction_number.operand_name for each operand that appears
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12747
// // in the replacement instruction's match rule
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12748
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12749
// ---------VM FLAGS---------------------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12750
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12751
// All peephole optimizations can be turned off using -XX:-OptoPeephole
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12752
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12753
// Each peephole rule is given an identifying number starting with zero and
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12754
// increasing by one in the order seen by the parser.  An individual peephole
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12755
// can be enabled, and all others disabled, by using -XX:OptoPeepholeAt=#
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12756
// on the command-line.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12757
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12758
// ---------CURRENT LIMITATIONS----------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12759
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12760
// Only match adjacent instructions in same basic block
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12761
// Only equality constraints
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12762
// Only constraints between operands, not (0.dest_reg == RAX_enc)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12763
// Only one replacement instruction
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12764
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12765
// ---------EXAMPLE----------------------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12766
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12767
// // pertinent parts of existing instructions in architecture description
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12768
// instruct movI(rRegI dst, rRegI src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12769
// %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12770
//   match(Set dst (CopyI src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12771
// %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12772
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12773
// instruct incI_rReg(rRegI dst, immI1 src, rFlagsReg cr)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12774
// %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12775
//   match(Set dst (AddI dst src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12776
//   effect(KILL cr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12777
// %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12778
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12779
// // Change (inc mov) to lea
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12780
// peephole %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12781
//   // increment preceeded by register-register move
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12782
//   peepmatch ( incI_rReg movI );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12783
//   // require that the destination register of the increment
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12784
//   // match the destination register of the move
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12785
//   peepconstraint ( 0.dst == 1.dst );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12786
//   // construct a replacement instruction that sets
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12787
//   // the destination to ( move's source register + one )
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12788
//   peepreplace ( leaI_rReg_immI( 0.dst 1.src 0.src ) );
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12789
// %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12790
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12791
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12792
// Implementation no longer uses movX instructions since
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12793
// machine-independent system no longer uses CopyX nodes.
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12794
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12795
// peephole
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12796
// %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12797
//   peepmatch (incI_rReg movI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12798
//   peepconstraint (0.dst == 1.dst);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12799
//   peepreplace (leaI_rReg_immI(0.dst 1.src 0.src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12800
// %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12801
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12802
// peephole
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12803
// %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12804
//   peepmatch (decI_rReg movI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12805
//   peepconstraint (0.dst == 1.dst);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12806
//   peepreplace (leaI_rReg_immI(0.dst 1.src 0.src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12807
// %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12808
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12809
// peephole
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12810
// %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12811
//   peepmatch (addI_rReg_imm movI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12812
//   peepconstraint (0.dst == 1.dst);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12813
//   peepreplace (leaI_rReg_immI(0.dst 1.src 0.src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12814
// %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12815
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12816
// peephole
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12817
// %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12818
//   peepmatch (incL_rReg movL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12819
//   peepconstraint (0.dst == 1.dst);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12820
//   peepreplace (leaL_rReg_immL(0.dst 1.src 0.src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12821
// %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12822
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12823
// peephole
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12824
// %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12825
//   peepmatch (decL_rReg movL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12826
//   peepconstraint (0.dst == 1.dst);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12827
//   peepreplace (leaL_rReg_immL(0.dst 1.src 0.src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12828
// %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12829
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12830
// peephole
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12831
// %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12832
//   peepmatch (addL_rReg_imm movL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12833
//   peepconstraint (0.dst == 1.dst);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12834
//   peepreplace (leaL_rReg_immL(0.dst 1.src 0.src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12835
// %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12836
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12837
// peephole
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12838
// %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12839
//   peepmatch (addP_rReg_imm movP);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12840
//   peepconstraint (0.dst == 1.dst);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12841
//   peepreplace (leaP_rReg_imm(0.dst 1.src 0.src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12842
// %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12843
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12844
// // Change load of spilled value to only a spill
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12845
// instruct storeI(memory mem, rRegI src)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12846
// %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12847
//   match(Set mem (StoreI mem src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12848
// %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12849
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12850
// instruct loadI(rRegI dst, memory mem)
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12851
// %{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12852
//   match(Set dst (LoadI mem));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12853
// %}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12854
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12855
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12856
peephole
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12857
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12858
  peepmatch (loadI storeI);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12859
  peepconstraint (1.src == 0.dst, 1.mem == 0.mem);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12860
  peepreplace (storeI(1.mem 1.mem 1.src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12861
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12862
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12863
peephole
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12864
%{
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12865
  peepmatch (loadL storeL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12866
  peepconstraint (1.src == 0.dst, 1.mem == 0.mem);
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12867
  peepreplace (storeL(1.mem 1.mem 1.src));
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12868
%}
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12869
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12870
//----------SMARTSPILL RULES---------------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12871
// These must follow all instruction definitions as they use the names
489c9b5090e2 Initial load
duke
parents:
diff changeset
 12872
// defined in the instructions definitions.