hotspot/src/os_cpu/bsd_x86/vm/bytes_bsd_x86.inline.hpp
author duke
Wed, 05 Jul 2017 20:05:23 +0200
changeset 27222 422e90d83a4e
parent 14286 ec9e76cd402f
permissions -rw-r--r--
Merge
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
10565
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
     1
/*
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
     2
 * Copyright (c) 1999, 2010, Oracle and/or its affiliates. All rights reserved.
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
     4
 *
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
     7
 * published by the Free Software Foundation.
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
     8
 *
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
     9
 * This code is distributed in the hope that it will be useful, but WITHOUT
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    10
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    11
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    12
 * version 2 for more details (a copy is included in the LICENSE file that
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    13
 * accompanied this code).
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    14
 *
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    15
 * You should have received a copy of the GNU General Public License version
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    16
 * 2 along with this work; if not, write to the Free Software Foundation,
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    17
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    18
 *
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    19
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    20
 * or visit www.oracle.com if you need additional information or have any
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    21
 * questions.
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    22
 *
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    23
 */
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    24
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    25
#ifndef OS_CPU_BSD_X86_VM_BYTES_BSD_X86_INLINE_HPP
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    26
#define OS_CPU_BSD_X86_VM_BYTES_BSD_X86_INLINE_HPP
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    27
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    28
#ifdef __APPLE__
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    29
#include <libkern/OSByteOrder.h>
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    30
#endif
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    31
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    32
#if defined(AMD64)
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    33
#  if defined(__APPLE__)
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    34
#    define bswap_16(x) OSSwapInt16(x)
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    35
#    define bswap_32(x) OSSwapInt32(x)
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    36
#    define bswap_64(x) OSSwapInt64(x)
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    37
#  elif defined(__OpenBSD__)
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    38
#    define bswap_16(x) swap16(x)
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    39
#    define bswap_32(x) swap32(x)
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    40
#    define bswap_64(x) swap64(x)
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    41
#  elif defined(__NetBSD__)
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    42
#    define bswap_16(x) bswap16(x)
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    43
#    define bswap_32(x) bswap32(x)
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    44
#    define bswap_64(x) bswap64(x)
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    45
#  else
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    46
#    define bswap_16(x) __bswap16(x)
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    47
#    define bswap_32(x) __bswap32(x)
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    48
#    define bswap_64(x) __bswap64(x)
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    49
#  endif
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    50
#endif
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    51
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    52
// Efficient swapping of data bytes from Java byte
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    53
// ordering to native byte ordering and vice versa.
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    54
inline u2   Bytes::swap_u2(u2 x) {
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    55
#ifdef AMD64
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    56
  return bswap_16(x);
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    57
#else
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    58
  u2 ret;
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    59
  __asm__ __volatile__ (
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    60
    "movw %0, %%ax;"
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    61
    "xchg %%al, %%ah;"
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    62
    "movw %%ax, %0"
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    63
    :"=r" (ret)      // output : register 0 => ret
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    64
    :"0"  (x)        // input  : x => register 0
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    65
    :"ax", "0"       // clobbered registers
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    66
  );
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    67
  return ret;
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    68
#endif // AMD64
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    69
}
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    70
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    71
inline u4   Bytes::swap_u4(u4 x) {
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    72
#ifdef AMD64
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    73
  return bswap_32(x);
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    74
#else
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    75
  u4 ret;
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    76
  __asm__ __volatile__ (
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    77
    "bswap %0"
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    78
    :"=r" (ret)      // output : register 0 => ret
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    79
    :"0"  (x)        // input  : x => register 0
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    80
    :"0"             // clobbered register
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    81
  );
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    82
  return ret;
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    83
#endif // AMD64
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    84
}
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    85
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    86
#ifdef AMD64
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    87
inline u8 Bytes::swap_u8(u8 x) {
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    88
#ifdef SPARC_WORKS
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    89
  // workaround for SunStudio12 CR6615391
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    90
  __asm__ __volatile__ (
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    91
    "bswapq %0"
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    92
    :"=r" (x)        // output : register 0 => x
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    93
    :"0"  (x)        // input  : x => register 0
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    94
    :"0"             // clobbered register
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    95
  );
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    96
  return x;
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    97
#else
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    98
  return bswap_64(x);
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
    99
#endif
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
   100
}
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
   101
#else
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
   102
// Helper function for swap_u8
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
   103
inline u8   Bytes::swap_u8_base(u4 x, u4 y) {
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
   104
  return (((u8)swap_u4(x))<<32) | swap_u4(y);
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
   105
}
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
   106
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
   107
inline u8 Bytes::swap_u8(u8 x) {
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
   108
  return swap_u8_base(*(u4*)&x, *(((u4*)&x)+1));
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
   109
}
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
   110
#endif // !AMD64
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
   111
dc90c239f4ec 7089790: integrate bsd-port changes
never
parents:
diff changeset
   112
#endif // OS_CPU_BSD_X86_VM_BYTES_BSD_X86_INLINE_HPP