hotspot/src/os_cpu/solaris_x86/vm/solaris_x86_32.il
author vdeshpande
Wed, 07 Jun 2017 13:09:46 -0700
changeset 46528 cf0da758e7b5
parent 46523 cbcc0ebaa044
permissions -rw-r--r--
8181616: FMA Vectorization on x86 Reviewed-by: kvn
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
     1
//
46414
5d1d862dc8d8 8169061: Drop os::is_MP checks from Atomics
shade
parents: 29456
diff changeset
     2
// Copyright (c) 2003, 2017, Oracle and/or its affiliates. All rights reserved.
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
     3
// DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
489c9b5090e2 Initial load
duke
parents:
diff changeset
     4
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
     5
// This code is free software; you can redistribute it and/or modify it
489c9b5090e2 Initial load
duke
parents:
diff changeset
     6
// under the terms of the GNU General Public License version 2 only, as
489c9b5090e2 Initial load
duke
parents:
diff changeset
     7
// published by the Free Software Foundation.
489c9b5090e2 Initial load
duke
parents:
diff changeset
     8
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
     9
// This code is distributed in the hope that it will be useful, but WITHOUT
489c9b5090e2 Initial load
duke
parents:
diff changeset
    10
// ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
489c9b5090e2 Initial load
duke
parents:
diff changeset
    11
// FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
489c9b5090e2 Initial load
duke
parents:
diff changeset
    12
// version 2 for more details (a copy is included in the LICENSE file that
489c9b5090e2 Initial load
duke
parents:
diff changeset
    13
// accompanied this code).
489c9b5090e2 Initial load
duke
parents:
diff changeset
    14
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
    15
// You should have received a copy of the GNU General Public License version
489c9b5090e2 Initial load
duke
parents:
diff changeset
    16
// 2 along with this work; if not, write to the Free Software Foundation,
489c9b5090e2 Initial load
duke
parents:
diff changeset
    17
// Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    18
//
5547
f4b087cbb361 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 5542
diff changeset
    19
// Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
f4b087cbb361 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 5542
diff changeset
    20
// or visit www.oracle.com if you need additional information or have any
f4b087cbb361 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 5542
diff changeset
    21
// questions.
29456
cc1c5203e60d 7143664: Clean up OrderAccess implementations and usage
dholmes
parents: 27691
diff changeset
    22
//
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    23
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
    24
489c9b5090e2 Initial load
duke
parents:
diff changeset
    25
489c9b5090e2 Initial load
duke
parents:
diff changeset
    26
  // Support for u8 os::setup_fpu()
489c9b5090e2 Initial load
duke
parents:
diff changeset
    27
      .inline _solaris_raw_setup_fpu,1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    28
      movl     0(%esp), %eax
489c9b5090e2 Initial load
duke
parents:
diff changeset
    29
      fldcw    (%eax)
489c9b5090e2 Initial load
duke
parents:
diff changeset
    30
      .end
489c9b5090e2 Initial load
duke
parents:
diff changeset
    31
489c9b5090e2 Initial load
duke
parents:
diff changeset
    32
  // The argument size of each inline directive is ignored by the compiler
489c9b5090e2 Initial load
duke
parents:
diff changeset
    33
  // and is set to 0 for compatibility reason.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    34
489c9b5090e2 Initial load
duke
parents:
diff changeset
    35
  // Get the raw thread ID from %gs:0
489c9b5090e2 Initial load
duke
parents:
diff changeset
    36
      .inline _raw_thread_id,0
29456
cc1c5203e60d 7143664: Clean up OrderAccess implementations and usage
dholmes
parents: 27691
diff changeset
    37
      movl     %gs:0, %eax
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    38
      .end
489c9b5090e2 Initial load
duke
parents:
diff changeset
    39
11961
0abd4cd26e5a 7147740: add assertions to check stack alignment on VM entry from generated code (x64)
roland
parents: 11417
diff changeset
    40
  // Get current sp
0abd4cd26e5a 7147740: add assertions to check stack alignment on VM entry from generated code (x64)
roland
parents: 11417
diff changeset
    41
      .inline _get_current_sp,0
0abd4cd26e5a 7147740: add assertions to check stack alignment on VM entry from generated code (x64)
roland
parents: 11417
diff changeset
    42
      .volatile
29456
cc1c5203e60d 7143664: Clean up OrderAccess implementations and usage
dholmes
parents: 27691
diff changeset
    43
      movl     %esp, %eax
11961
0abd4cd26e5a 7147740: add assertions to check stack alignment on VM entry from generated code (x64)
roland
parents: 11417
diff changeset
    44
      .end
0abd4cd26e5a 7147740: add assertions to check stack alignment on VM entry from generated code (x64)
roland
parents: 11417
diff changeset
    45
1659
b9a3819ac7c6 6773838: There is no calling stack for Compiler thread in hs_err file on x86
coleenp
parents: 1
diff changeset
    46
  // Get current fp
b9a3819ac7c6 6773838: There is no calling stack for Compiler thread in hs_err file on x86
coleenp
parents: 1
diff changeset
    47
      .inline _get_current_fp,0
b9a3819ac7c6 6773838: There is no calling stack for Compiler thread in hs_err file on x86
coleenp
parents: 1
diff changeset
    48
      .volatile
29456
cc1c5203e60d 7143664: Clean up OrderAccess implementations and usage
dholmes
parents: 27691
diff changeset
    49
      movl     %ebp, %eax
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    50
      .end
489c9b5090e2 Initial load
duke
parents:
diff changeset
    51
11417
4ecc3253bec4 7125934: Add a fast unordered timestamp capability to Hotspot on x86/x64
phh
parents: 7891
diff changeset
    52
  // Support for os::rdtsc()
4ecc3253bec4 7125934: Add a fast unordered timestamp capability to Hotspot on x86/x64
phh
parents: 7891
diff changeset
    53
      .inline _raw_rdtsc,0
4ecc3253bec4 7125934: Add a fast unordered timestamp capability to Hotspot on x86/x64
phh
parents: 7891
diff changeset
    54
      rdtsc
4ecc3253bec4 7125934: Add a fast unordered timestamp capability to Hotspot on x86/x64
phh
parents: 7891
diff changeset
    55
      .end
4ecc3253bec4 7125934: Add a fast unordered timestamp capability to Hotspot on x86/x64
phh
parents: 7891
diff changeset
    56
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    57
  // Support for jint Atomic::add(jint inc, volatile jint* dest)
489c9b5090e2 Initial load
duke
parents:
diff changeset
    58
      .inline _Atomic_add,3
489c9b5090e2 Initial load
duke
parents:
diff changeset
    59
      movl     0(%esp), %eax   // inc
489c9b5090e2 Initial load
duke
parents:
diff changeset
    60
      movl     4(%esp), %edx   // dest
489c9b5090e2 Initial load
duke
parents:
diff changeset
    61
      movl     %eax, %ecx
46414
5d1d862dc8d8 8169061: Drop os::is_MP checks from Atomics
shade
parents: 29456
diff changeset
    62
      lock xaddl %eax, (%edx)
5d1d862dc8d8 8169061: Drop os::is_MP checks from Atomics
shade
parents: 29456
diff changeset
    63
      addl     %ecx, %eax
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    64
      .end
489c9b5090e2 Initial load
duke
parents:
diff changeset
    65
489c9b5090e2 Initial load
duke
parents:
diff changeset
    66
  // Support for jint Atomic::xchg(jint exchange_value, volatile jint* dest).
489c9b5090e2 Initial load
duke
parents:
diff changeset
    67
      .inline _Atomic_xchg,2
489c9b5090e2 Initial load
duke
parents:
diff changeset
    68
      movl     0(%esp), %eax   // exchange_value
489c9b5090e2 Initial load
duke
parents:
diff changeset
    69
      movl     4(%esp), %ecx   // dest
489c9b5090e2 Initial load
duke
parents:
diff changeset
    70
      xchgl    (%ecx), %eax
489c9b5090e2 Initial load
duke
parents:
diff changeset
    71
      .end
489c9b5090e2 Initial load
duke
parents:
diff changeset
    72
29456
cc1c5203e60d 7143664: Clean up OrderAccess implementations and usage
dholmes
parents: 27691
diff changeset
    73
  // Support for jbyte Atomic::cmpxchg(jbyte exchange_value,
cc1c5203e60d 7143664: Clean up OrderAccess implementations and usage
dholmes
parents: 27691
diff changeset
    74
  //                                   volatile jbyte *dest,
27691
733f189ad1f7 8058255: Native jbyte Atomic::cmpxchg for supported x86 platforms
jwilhelm
parents: 13963
diff changeset
    75
  //                                   jbyte compare_value)
733f189ad1f7 8058255: Native jbyte Atomic::cmpxchg for supported x86 platforms
jwilhelm
parents: 13963
diff changeset
    76
      .inline _Atomic_cmpxchg_byte,4
733f189ad1f7 8058255: Native jbyte Atomic::cmpxchg for supported x86 platforms
jwilhelm
parents: 13963
diff changeset
    77
      movb     8(%esp), %al   // compare_value
733f189ad1f7 8058255: Native jbyte Atomic::cmpxchg for supported x86 platforms
jwilhelm
parents: 13963
diff changeset
    78
      movb     0(%esp), %cl   // exchange_value
733f189ad1f7 8058255: Native jbyte Atomic::cmpxchg for supported x86 platforms
jwilhelm
parents: 13963
diff changeset
    79
      movl     4(%esp), %edx   // dest
46414
5d1d862dc8d8 8169061: Drop os::is_MP checks from Atomics
shade
parents: 29456
diff changeset
    80
      lock cmpxchgb %cl, (%edx)
27691
733f189ad1f7 8058255: Native jbyte Atomic::cmpxchg for supported x86 platforms
jwilhelm
parents: 13963
diff changeset
    81
      .end
733f189ad1f7 8058255: Native jbyte Atomic::cmpxchg for supported x86 platforms
jwilhelm
parents: 13963
diff changeset
    82
29456
cc1c5203e60d 7143664: Clean up OrderAccess implementations and usage
dholmes
parents: 27691
diff changeset
    83
  // Support for jint Atomic::cmpxchg(jint exchange_value,
cc1c5203e60d 7143664: Clean up OrderAccess implementations and usage
dholmes
parents: 27691
diff changeset
    84
  //                                  volatile jint *dest,
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    85
  //                                  jint compare_value)
489c9b5090e2 Initial load
duke
parents:
diff changeset
    86
      .inline _Atomic_cmpxchg,4
489c9b5090e2 Initial load
duke
parents:
diff changeset
    87
      movl     8(%esp), %eax   // compare_value
489c9b5090e2 Initial load
duke
parents:
diff changeset
    88
      movl     0(%esp), %ecx   // exchange_value
489c9b5090e2 Initial load
duke
parents:
diff changeset
    89
      movl     4(%esp), %edx   // dest
46414
5d1d862dc8d8 8169061: Drop os::is_MP checks from Atomics
shade
parents: 29456
diff changeset
    90
      lock cmpxchgl %ecx, (%edx)
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    91
      .end
489c9b5090e2 Initial load
duke
parents:
diff changeset
    92
489c9b5090e2 Initial load
duke
parents:
diff changeset
    93
  // Support for jlong Atomic::cmpxchg(jlong exchange_value,
489c9b5090e2 Initial load
duke
parents:
diff changeset
    94
  //                                   volatile jlong* dest,
489c9b5090e2 Initial load
duke
parents:
diff changeset
    95
  //                                   jlong compare_value)
489c9b5090e2 Initial load
duke
parents:
diff changeset
    96
      .inline _Atomic_cmpxchg_long,6
489c9b5090e2 Initial load
duke
parents:
diff changeset
    97
      pushl    %ebx
489c9b5090e2 Initial load
duke
parents:
diff changeset
    98
      pushl    %edi
489c9b5090e2 Initial load
duke
parents:
diff changeset
    99
      movl     20(%esp), %eax  // compare_value (low)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   100
      movl     24(%esp), %edx  // compare_value (high)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   101
      movl     16(%esp), %edi  // dest
489c9b5090e2 Initial load
duke
parents:
diff changeset
   102
      movl     8(%esp), %ebx   // exchange_value (low)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   103
      movl     12(%esp), %ecx  // exchange_high (high)
46414
5d1d862dc8d8 8169061: Drop os::is_MP checks from Atomics
shade
parents: 29456
diff changeset
   104
      lock cmpxchg8b (%edi)
5d1d862dc8d8 8169061: Drop os::is_MP checks from Atomics
shade
parents: 29456
diff changeset
   105
      popl     %edi
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   106
      popl     %ebx
489c9b5090e2 Initial load
duke
parents:
diff changeset
   107
      .end
489c9b5090e2 Initial load
duke
parents:
diff changeset
   108
7885
c02b05ba16a1 7009756: volatile variables could be broken throw reflection API
kvn
parents: 5547
diff changeset
   109
  // Support for jlong Atomic::load and Atomic::store.
46523
cbcc0ebaa044 8166651: OrderAccess::load_acquire &etc should have const parameters
kbarrett
parents: 46414
diff changeset
   110
  // void _Atomic_move_long(const volatile jlong* src, volatile jlong* dst)
7885
c02b05ba16a1 7009756: volatile variables could be broken throw reflection API
kvn
parents: 5547
diff changeset
   111
      .inline _Atomic_move_long,2
3594
0ce9158bc84c 6863420: os::javaTimeNanos() go backward on Solaris x86
kvn
parents: 2105
diff changeset
   112
      movl     0(%esp), %eax   // src
0ce9158bc84c 6863420: os::javaTimeNanos() go backward on Solaris x86
kvn
parents: 2105
diff changeset
   113
      fildll    (%eax)
0ce9158bc84c 6863420: os::javaTimeNanos() go backward on Solaris x86
kvn
parents: 2105
diff changeset
   114
      movl     4(%esp), %eax   // dest
0ce9158bc84c 6863420: os::javaTimeNanos() go backward on Solaris x86
kvn
parents: 2105
diff changeset
   115
      fistpll   (%eax)
0ce9158bc84c 6863420: os::javaTimeNanos() go backward on Solaris x86
kvn
parents: 2105
diff changeset
   116
      .end
0ce9158bc84c 6863420: os::javaTimeNanos() go backward on Solaris x86
kvn
parents: 2105
diff changeset
   117
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   118
  // Support for u2 Bytes::swap_u2(u2 x)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   119
      .inline _raw_swap_u2,1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   120
      movl     0(%esp), %eax
489c9b5090e2 Initial load
duke
parents:
diff changeset
   121
      xchgb    %al, %ah
489c9b5090e2 Initial load
duke
parents:
diff changeset
   122
      .end
489c9b5090e2 Initial load
duke
parents:
diff changeset
   123
489c9b5090e2 Initial load
duke
parents:
diff changeset
   124
  // Support for u4 Bytes::swap_u4(u4 x)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   125
      .inline _raw_swap_u4,1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   126
      movl     0(%esp), %eax
489c9b5090e2 Initial load
duke
parents:
diff changeset
   127
      bswap    %eax
489c9b5090e2 Initial load
duke
parents:
diff changeset
   128
      .end
489c9b5090e2 Initial load
duke
parents:
diff changeset
   129
489c9b5090e2 Initial load
duke
parents:
diff changeset
   130
  // Support for u8 Bytes::swap_u8_base(u4 x, u4 y)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   131
      .inline _raw_swap_u8,2
489c9b5090e2 Initial load
duke
parents:
diff changeset
   132
      movl     4(%esp), %eax   // y
489c9b5090e2 Initial load
duke
parents:
diff changeset
   133
      movl     0(%esp), %edx   // x
489c9b5090e2 Initial load
duke
parents:
diff changeset
   134
      bswap    %eax
489c9b5090e2 Initial load
duke
parents:
diff changeset
   135
      bswap    %edx
489c9b5090e2 Initial load
duke
parents:
diff changeset
   136
      .end