src/hotspot/cpu/ppc/register_ppc.hpp
author coleenp
Wed, 14 Aug 2019 10:07:00 -0400
changeset 57745 789e967c2731
parent 53244 9807daeb47c4
permissions -rw-r--r--
5103339: Strengthen NoSafepointVerifier Summary: Add NSV check at possible safepoint transition or places that could take out locks. Consolidate with clearing unhandled oops. Reviewed-by: dholmes, rehn
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
22824
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
     1
/*
53244
9807daeb47c4 8216167: Update include guards to reflect correct directories
coleenp
parents: 51777
diff changeset
     2
 * Copyright (c) 2000, 2019, Oracle and/or its affiliates. All rights reserved.
51710
355bd23b46e5 8210497: [PPC64] Vector registers not saved across safepoint
mdoerr
parents: 47583
diff changeset
     3
 * Copyright (c) 2012, 2018 SAP SE. All rights reserved.
22824
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
     4
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
     5
 *
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
     6
 * This code is free software; you can redistribute it and/or modify it
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
     7
 * under the terms of the GNU General Public License version 2 only, as
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
     8
 * published by the Free Software Foundation.
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
     9
 *
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    10
 * This code is distributed in the hope that it will be useful, but WITHOUT
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    11
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    12
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    13
 * version 2 for more details (a copy is included in the LICENSE file that
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    14
 * accompanied this code).
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    15
 *
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    16
 * You should have received a copy of the GNU General Public License version
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    17
 * 2 along with this work; if not, write to the Free Software Foundation,
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    18
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    19
 *
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    20
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    21
 * or visit www.oracle.com if you need additional information or have any
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    22
 * questions.
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    23
 *
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    24
 */
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    25
53244
9807daeb47c4 8216167: Update include guards to reflect correct directories
coleenp
parents: 51777
diff changeset
    26
#ifndef CPU_PPC_REGISTER_PPC_HPP
9807daeb47c4 8216167: Update include guards to reflect correct directories
coleenp
parents: 51777
diff changeset
    27
#define CPU_PPC_REGISTER_PPC_HPP
22824
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    28
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    29
#include "asm/register.hpp"
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    30
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    31
// forward declaration
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    32
class Address;
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    33
class VMRegImpl;
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    34
typedef VMRegImpl* VMReg;
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    35
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    36
//  PPC64 registers
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    37
//
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    38
//  See "64-bit PowerPC ELF ABI Supplement 1.7", IBM Corp. (2003-10-29).
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    39
//  (http://math-atlas.sourceforge.net/devel/assembly/PPC-elf64abi-1.7.pdf)
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    40
//
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    41
//  r0        Register used in function prologs (volatile)
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    42
//  r1        Stack pointer (nonvolatile)
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    43
//  r2        TOC pointer (volatile)
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    44
//  r3        Parameter and return value (volatile)
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    45
//  r4-r10    Function parameters (volatile)
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    46
//  r11       Register used in calls by pointer and as an environment pointer for languages which require one (volatile)
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    47
//  r12       Register used for exception handling and glink code (volatile)
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    48
//  r13       Reserved for use as system thread ID
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    49
//  r14-r31   Local variables (nonvolatile)
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    50
//
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    51
//  f0        Scratch register (volatile)
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    52
//  f1-f4     Floating point parameters and return value (volatile)
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    53
//  f5-f13    Floating point parameters (volatile)
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    54
//  f14-f31   Floating point values (nonvolatile)
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    55
//
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    56
//  LR        Link register for return address (volatile)
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    57
//  CTR       Loop counter (volatile)
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    58
//  XER       Fixed point exception register (volatile)
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    59
//  FPSCR     Floating point status and control register (volatile)
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    60
//
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    61
//  CR0-CR1   Condition code fields (volatile)
22861
f5c393d456fc 8029940: PPC64 (part 122): C2 compiler port
goetz
parents: 22824
diff changeset
    62
//  CR2-CR4   Condition code fields (nonvolatile)
f5c393d456fc 8029940: PPC64 (part 122): C2 compiler port
goetz
parents: 22824
diff changeset
    63
//  CR5-CR7   Condition code fields (volatile)
22824
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    64
//
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    65
//  ----------------------------------------------
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    66
//  On processors with the VMX feature:
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    67
//  v0-v1     Volatile scratch registers
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    68
//  v2-v13    Volatile vector parameters registers
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    69
//  v14-v19   Volatile scratch registers
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    70
//  v20-v31   Non-volatile registers
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    71
//  vrsave    Non-volatile 32-bit register
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    72
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    73
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    74
// Use Register as shortcut
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    75
class RegisterImpl;
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    76
typedef RegisterImpl* Register;
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    77
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    78
inline Register as_Register(int encoding) {
40071
53e12df44b7b 8160245: C1: Clean up platform #defines in c1_LIR.hpp.
goetz
parents: 39236
diff changeset
    79
  assert(encoding >= -1 && encoding < 32, "bad register encoding");
22824
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    80
  return (Register)(intptr_t)encoding;
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    81
}
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    82
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    83
// The implementation of integer registers for the Power architecture
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    84
class RegisterImpl: public AbstractRegisterImpl {
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    85
 public:
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    86
  enum {
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    87
    number_of_registers = 32
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    88
  };
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    89
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    90
  // general construction
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    91
  inline friend Register as_Register(int encoding);
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    92
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    93
  // accessors
40071
53e12df44b7b 8160245: C1: Clean up platform #defines in c1_LIR.hpp.
goetz
parents: 39236
diff changeset
    94
  int encoding() const { assert(is_valid(), "invalid register"); return value(); }
25715
d5a8dbdc5150 8049325: Introduce and clean up umbrella headers for the files in the cpu subdirectories.
goetz
parents: 23221
diff changeset
    95
  inline VMReg as_VMReg();
22824
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    96
  Register successor() const { return as_Register(encoding() + 1); }
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    97
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    98
  // testers
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
    99
  bool is_valid()       const { return ( 0 <= (value()&0x7F) && (value()&0x7F) <  number_of_registers); }
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   100
  bool is_volatile()    const { return ( 0 <= (value()&0x7F) && (value()&0x7F) <= 13 ); }
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   101
  bool is_nonvolatile() const { return (14 <= (value()&0x7F) && (value()&0x7F) <= 31 ); }
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   102
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   103
  const char* name() const;
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   104
};
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   105
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   106
// The integer registers of the PPC architecture
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   107
CONSTANT_REGISTER_DECLARATION(Register, noreg, (-1));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   108
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   109
CONSTANT_REGISTER_DECLARATION(Register, R0,   (0));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   110
CONSTANT_REGISTER_DECLARATION(Register, R1,   (1));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   111
CONSTANT_REGISTER_DECLARATION(Register, R2,   (2));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   112
CONSTANT_REGISTER_DECLARATION(Register, R3,   (3));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   113
CONSTANT_REGISTER_DECLARATION(Register, R4,   (4));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   114
CONSTANT_REGISTER_DECLARATION(Register, R5,   (5));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   115
CONSTANT_REGISTER_DECLARATION(Register, R6,   (6));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   116
CONSTANT_REGISTER_DECLARATION(Register, R7,   (7));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   117
CONSTANT_REGISTER_DECLARATION(Register, R8,   (8));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   118
CONSTANT_REGISTER_DECLARATION(Register, R9,   (9));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   119
CONSTANT_REGISTER_DECLARATION(Register, R10, (10));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   120
CONSTANT_REGISTER_DECLARATION(Register, R11, (11));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   121
CONSTANT_REGISTER_DECLARATION(Register, R12, (12));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   122
CONSTANT_REGISTER_DECLARATION(Register, R13, (13));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   123
CONSTANT_REGISTER_DECLARATION(Register, R14, (14));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   124
CONSTANT_REGISTER_DECLARATION(Register, R15, (15));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   125
CONSTANT_REGISTER_DECLARATION(Register, R16, (16));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   126
CONSTANT_REGISTER_DECLARATION(Register, R17, (17));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   127
CONSTANT_REGISTER_DECLARATION(Register, R18, (18));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   128
CONSTANT_REGISTER_DECLARATION(Register, R19, (19));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   129
CONSTANT_REGISTER_DECLARATION(Register, R20, (20));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   130
CONSTANT_REGISTER_DECLARATION(Register, R21, (21));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   131
CONSTANT_REGISTER_DECLARATION(Register, R22, (22));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   132
CONSTANT_REGISTER_DECLARATION(Register, R23, (23));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   133
CONSTANT_REGISTER_DECLARATION(Register, R24, (24));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   134
CONSTANT_REGISTER_DECLARATION(Register, R25, (25));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   135
CONSTANT_REGISTER_DECLARATION(Register, R26, (26));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   136
CONSTANT_REGISTER_DECLARATION(Register, R27, (27));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   137
CONSTANT_REGISTER_DECLARATION(Register, R28, (28));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   138
CONSTANT_REGISTER_DECLARATION(Register, R29, (29));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   139
CONSTANT_REGISTER_DECLARATION(Register, R30, (30));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   140
CONSTANT_REGISTER_DECLARATION(Register, R31, (31));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   141
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   142
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   143
//
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   144
// Because Power has many registers, #define'ing values for them is
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   145
// beneficial in code size and is worth the cost of some of the
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   146
// dangers of defines. If a particular file has a problem with these
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   147
// defines then it's possible to turn them off in that file by
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   148
// defining DONT_USE_REGISTER_DEFINES. Register_definition_ppc.cpp
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   149
// does that so that it's able to provide real definitions of these
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   150
// registers for use in debuggers and such.
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   151
//
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   152
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   153
#ifndef DONT_USE_REGISTER_DEFINES
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   154
#define noreg ((Register)(noreg_RegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   155
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   156
#define R0 ((Register)(R0_RegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   157
#define R1 ((Register)(R1_RegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   158
#define R2 ((Register)(R2_RegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   159
#define R3 ((Register)(R3_RegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   160
#define R4 ((Register)(R4_RegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   161
#define R5 ((Register)(R5_RegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   162
#define R6 ((Register)(R6_RegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   163
#define R7 ((Register)(R7_RegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   164
#define R8 ((Register)(R8_RegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   165
#define R9 ((Register)(R9_RegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   166
#define R10 ((Register)(R10_RegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   167
#define R11 ((Register)(R11_RegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   168
#define R12 ((Register)(R12_RegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   169
#define R13 ((Register)(R13_RegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   170
#define R14 ((Register)(R14_RegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   171
#define R15 ((Register)(R15_RegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   172
#define R16 ((Register)(R16_RegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   173
#define R17 ((Register)(R17_RegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   174
#define R18 ((Register)(R18_RegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   175
#define R19 ((Register)(R19_RegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   176
#define R20 ((Register)(R20_RegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   177
#define R21 ((Register)(R21_RegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   178
#define R22 ((Register)(R22_RegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   179
#define R23 ((Register)(R23_RegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   180
#define R24 ((Register)(R24_RegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   181
#define R25 ((Register)(R25_RegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   182
#define R26 ((Register)(R26_RegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   183
#define R27 ((Register)(R27_RegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   184
#define R28 ((Register)(R28_RegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   185
#define R29 ((Register)(R29_RegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   186
#define R30 ((Register)(R30_RegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   187
#define R31 ((Register)(R31_RegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   188
#endif
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   189
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   190
// Use ConditionRegister as shortcut
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   191
class ConditionRegisterImpl;
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   192
typedef ConditionRegisterImpl* ConditionRegister;
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   193
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   194
inline ConditionRegister as_ConditionRegister(int encoding) {
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   195
  assert(encoding >= 0 && encoding < 8, "bad condition register encoding");
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   196
  return (ConditionRegister)(intptr_t)encoding;
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   197
}
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   198
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   199
// The implementation of condition register(s) for the PPC architecture
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   200
class ConditionRegisterImpl: public AbstractRegisterImpl {
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   201
 public:
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   202
  enum {
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   203
    number_of_registers = 8
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   204
  };
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   205
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   206
  // construction.
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   207
  inline friend ConditionRegister as_ConditionRegister(int encoding);
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   208
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   209
  // accessors
25715
d5a8dbdc5150 8049325: Introduce and clean up umbrella headers for the files in the cpu subdirectories.
goetz
parents: 23221
diff changeset
   210
  int encoding() const { assert(is_valid(), "invalid register"); return value(); }
d5a8dbdc5150 8049325: Introduce and clean up umbrella headers for the files in the cpu subdirectories.
goetz
parents: 23221
diff changeset
   211
  inline VMReg as_VMReg();
22824
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   212
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   213
  // testers
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   214
  bool is_valid()       const { return  (0 <= value()        &&  value() < number_of_registers); }
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   215
  bool is_nonvolatile() const { return  (2 <= (value()&0x7F) && (value()&0x7F) <= 4 );  }
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   216
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   217
  const char* name() const;
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   218
};
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   219
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   220
// The (parts of the) condition register(s) of the PPC architecture
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   221
// sys/ioctl.h on AIX defines CR0-CR3, so I name these CCR.
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   222
CONSTANT_REGISTER_DECLARATION(ConditionRegister, CCR0,   (0));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   223
CONSTANT_REGISTER_DECLARATION(ConditionRegister, CCR1,   (1));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   224
CONSTANT_REGISTER_DECLARATION(ConditionRegister, CCR2,   (2));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   225
CONSTANT_REGISTER_DECLARATION(ConditionRegister, CCR3,   (3));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   226
CONSTANT_REGISTER_DECLARATION(ConditionRegister, CCR4,   (4));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   227
CONSTANT_REGISTER_DECLARATION(ConditionRegister, CCR5,   (5));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   228
CONSTANT_REGISTER_DECLARATION(ConditionRegister, CCR6,   (6));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   229
CONSTANT_REGISTER_DECLARATION(ConditionRegister, CCR7,   (7));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   230
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   231
#ifndef DONT_USE_REGISTER_DEFINES
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   232
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   233
#define CCR0 ((ConditionRegister)(CCR0_ConditionRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   234
#define CCR1 ((ConditionRegister)(CCR1_ConditionRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   235
#define CCR2 ((ConditionRegister)(CCR2_ConditionRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   236
#define CCR3 ((ConditionRegister)(CCR3_ConditionRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   237
#define CCR4 ((ConditionRegister)(CCR4_ConditionRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   238
#define CCR5 ((ConditionRegister)(CCR5_ConditionRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   239
#define CCR6 ((ConditionRegister)(CCR6_ConditionRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   240
#define CCR7 ((ConditionRegister)(CCR7_ConditionRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   241
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   242
#endif // DONT_USE_REGISTER_DEFINES
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   243
51777
9c6d5e31618e 8210660: PPC64: Mapping floating point registers to vsx registers in ppc.ad
mhorie
parents: 51711
diff changeset
   244
// Forward declaration
9c6d5e31618e 8210660: PPC64: Mapping floating point registers to vsx registers in ppc.ad
mhorie
parents: 51711
diff changeset
   245
// Use VectorSRegister as a shortcut.
9c6d5e31618e 8210660: PPC64: Mapping floating point registers to vsx registers in ppc.ad
mhorie
parents: 51711
diff changeset
   246
class VectorSRegisterImpl;
9c6d5e31618e 8210660: PPC64: Mapping floating point registers to vsx registers in ppc.ad
mhorie
parents: 51711
diff changeset
   247
typedef VectorSRegisterImpl* VectorSRegister;
22824
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   248
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   249
// Use FloatRegister as shortcut
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   250
class FloatRegisterImpl;
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   251
typedef FloatRegisterImpl* FloatRegister;
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   252
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   253
inline FloatRegister as_FloatRegister(int encoding) {
40071
53e12df44b7b 8160245: C1: Clean up platform #defines in c1_LIR.hpp.
goetz
parents: 39236
diff changeset
   254
  assert(encoding >= -1 && encoding < 32, "bad float register encoding");
22824
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   255
  return (FloatRegister)(intptr_t)encoding;
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   256
}
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   257
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   258
// The implementation of float registers for the PPC architecture
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   259
class FloatRegisterImpl: public AbstractRegisterImpl {
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   260
 public:
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   261
  enum {
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   262
    number_of_registers = 32
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   263
  };
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   264
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   265
  // construction
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   266
  inline friend FloatRegister as_FloatRegister(int encoding);
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   267
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   268
  // accessors
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   269
  int           encoding() const { assert(is_valid(), "invalid register"); return value(); }
25715
d5a8dbdc5150 8049325: Introduce and clean up umbrella headers for the files in the cpu subdirectories.
goetz
parents: 23221
diff changeset
   270
  inline VMReg  as_VMReg();
22824
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   271
  FloatRegister successor() const { return as_FloatRegister(encoding() + 1); }
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   272
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   273
  // testers
40071
53e12df44b7b 8160245: C1: Clean up platform #defines in c1_LIR.hpp.
goetz
parents: 39236
diff changeset
   274
  bool is_valid() const { return (0 <= value() && value() < number_of_registers); }
22824
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   275
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   276
  const char* name() const;
51777
9c6d5e31618e 8210660: PPC64: Mapping floating point registers to vsx registers in ppc.ad
mhorie
parents: 51711
diff changeset
   277
9c6d5e31618e 8210660: PPC64: Mapping floating point registers to vsx registers in ppc.ad
mhorie
parents: 51711
diff changeset
   278
  // convert to VSR
9c6d5e31618e 8210660: PPC64: Mapping floating point registers to vsx registers in ppc.ad
mhorie
parents: 51711
diff changeset
   279
  VectorSRegister to_vsr() const;
22824
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   280
};
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   281
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   282
// The float registers of the PPC architecture
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   283
CONSTANT_REGISTER_DECLARATION(FloatRegister, fnoreg, (-1));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   284
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   285
CONSTANT_REGISTER_DECLARATION(FloatRegister, F0,  ( 0));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   286
CONSTANT_REGISTER_DECLARATION(FloatRegister, F1,  ( 1));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   287
CONSTANT_REGISTER_DECLARATION(FloatRegister, F2,  ( 2));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   288
CONSTANT_REGISTER_DECLARATION(FloatRegister, F3,  ( 3));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   289
CONSTANT_REGISTER_DECLARATION(FloatRegister, F4,  ( 4));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   290
CONSTANT_REGISTER_DECLARATION(FloatRegister, F5,  ( 5));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   291
CONSTANT_REGISTER_DECLARATION(FloatRegister, F6,  ( 6));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   292
CONSTANT_REGISTER_DECLARATION(FloatRegister, F7,  ( 7));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   293
CONSTANT_REGISTER_DECLARATION(FloatRegister, F8,  ( 8));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   294
CONSTANT_REGISTER_DECLARATION(FloatRegister, F9,  ( 9));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   295
CONSTANT_REGISTER_DECLARATION(FloatRegister, F10, (10));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   296
CONSTANT_REGISTER_DECLARATION(FloatRegister, F11, (11));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   297
CONSTANT_REGISTER_DECLARATION(FloatRegister, F12, (12));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   298
CONSTANT_REGISTER_DECLARATION(FloatRegister, F13, (13));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   299
CONSTANT_REGISTER_DECLARATION(FloatRegister, F14, (14));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   300
CONSTANT_REGISTER_DECLARATION(FloatRegister, F15, (15));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   301
CONSTANT_REGISTER_DECLARATION(FloatRegister, F16, (16));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   302
CONSTANT_REGISTER_DECLARATION(FloatRegister, F17, (17));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   303
CONSTANT_REGISTER_DECLARATION(FloatRegister, F18, (18));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   304
CONSTANT_REGISTER_DECLARATION(FloatRegister, F19, (19));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   305
CONSTANT_REGISTER_DECLARATION(FloatRegister, F20, (20));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   306
CONSTANT_REGISTER_DECLARATION(FloatRegister, F21, (21));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   307
CONSTANT_REGISTER_DECLARATION(FloatRegister, F22, (22));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   308
CONSTANT_REGISTER_DECLARATION(FloatRegister, F23, (23));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   309
CONSTANT_REGISTER_DECLARATION(FloatRegister, F24, (24));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   310
CONSTANT_REGISTER_DECLARATION(FloatRegister, F25, (25));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   311
CONSTANT_REGISTER_DECLARATION(FloatRegister, F26, (26));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   312
CONSTANT_REGISTER_DECLARATION(FloatRegister, F27, (27));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   313
CONSTANT_REGISTER_DECLARATION(FloatRegister, F28, (28));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   314
CONSTANT_REGISTER_DECLARATION(FloatRegister, F29, (29));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   315
CONSTANT_REGISTER_DECLARATION(FloatRegister, F30, (30));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   316
CONSTANT_REGISTER_DECLARATION(FloatRegister, F31, (31));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   317
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   318
#ifndef DONT_USE_REGISTER_DEFINES
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   319
#define fnoreg ((FloatRegister)(fnoreg_FloatRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   320
#define F0     ((FloatRegister)(    F0_FloatRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   321
#define F1     ((FloatRegister)(    F1_FloatRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   322
#define F2     ((FloatRegister)(    F2_FloatRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   323
#define F3     ((FloatRegister)(    F3_FloatRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   324
#define F4     ((FloatRegister)(    F4_FloatRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   325
#define F5     ((FloatRegister)(    F5_FloatRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   326
#define F6     ((FloatRegister)(    F6_FloatRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   327
#define F7     ((FloatRegister)(    F7_FloatRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   328
#define F8     ((FloatRegister)(    F8_FloatRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   329
#define F9     ((FloatRegister)(    F9_FloatRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   330
#define F10    ((FloatRegister)(   F10_FloatRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   331
#define F11    ((FloatRegister)(   F11_FloatRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   332
#define F12    ((FloatRegister)(   F12_FloatRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   333
#define F13    ((FloatRegister)(   F13_FloatRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   334
#define F14    ((FloatRegister)(   F14_FloatRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   335
#define F15    ((FloatRegister)(   F15_FloatRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   336
#define F16    ((FloatRegister)(   F16_FloatRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   337
#define F17    ((FloatRegister)(   F17_FloatRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   338
#define F18    ((FloatRegister)(   F18_FloatRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   339
#define F19    ((FloatRegister)(   F19_FloatRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   340
#define F20    ((FloatRegister)(   F20_FloatRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   341
#define F21    ((FloatRegister)(   F21_FloatRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   342
#define F22    ((FloatRegister)(   F22_FloatRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   343
#define F23    ((FloatRegister)(   F23_FloatRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   344
#define F24    ((FloatRegister)(   F24_FloatRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   345
#define F25    ((FloatRegister)(   F25_FloatRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   346
#define F26    ((FloatRegister)(   F26_FloatRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   347
#define F27    ((FloatRegister)(   F27_FloatRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   348
#define F28    ((FloatRegister)(   F28_FloatRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   349
#define F29    ((FloatRegister)(   F29_FloatRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   350
#define F30    ((FloatRegister)(   F30_FloatRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   351
#define F31    ((FloatRegister)(   F31_FloatRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   352
#endif // DONT_USE_REGISTER_DEFINES
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   353
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   354
// Use SpecialRegister as shortcut
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   355
class SpecialRegisterImpl;
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   356
typedef SpecialRegisterImpl* SpecialRegister;
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   357
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   358
inline SpecialRegister as_SpecialRegister(int encoding) {
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   359
  return (SpecialRegister)(intptr_t)encoding;
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   360
}
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   361
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   362
// The implementation of special registers for the Power architecture (LR, CTR and friends)
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   363
class SpecialRegisterImpl: public AbstractRegisterImpl {
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   364
 public:
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   365
  enum {
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   366
    number_of_registers = 6
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   367
  };
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   368
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   369
  // construction
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   370
  inline friend SpecialRegister as_SpecialRegister(int encoding);
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   371
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   372
  // accessors
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   373
  int             encoding()  const { assert(is_valid(), "invalid register"); return value(); }
25715
d5a8dbdc5150 8049325: Introduce and clean up umbrella headers for the files in the cpu subdirectories.
goetz
parents: 23221
diff changeset
   374
  inline VMReg    as_VMReg();
22824
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   375
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   376
  // testers
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   377
  bool is_valid()       const { return 0 <= value() && value() < number_of_registers; }
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   378
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   379
  const char* name() const;
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   380
};
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   381
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   382
// The special registers of the PPC architecture
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   383
CONSTANT_REGISTER_DECLARATION(SpecialRegister, SR_XER,     (0));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   384
CONSTANT_REGISTER_DECLARATION(SpecialRegister, SR_LR,      (1));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   385
CONSTANT_REGISTER_DECLARATION(SpecialRegister, SR_CTR,     (2));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   386
CONSTANT_REGISTER_DECLARATION(SpecialRegister, SR_VRSAVE,  (3));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   387
CONSTANT_REGISTER_DECLARATION(SpecialRegister, SR_SPEFSCR, (4));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   388
CONSTANT_REGISTER_DECLARATION(SpecialRegister, SR_PPR,     (5));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   389
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   390
#ifndef DONT_USE_REGISTER_DEFINES
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   391
#define SR_XER     ((SpecialRegister)(SR_XER_SpecialRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   392
#define SR_LR      ((SpecialRegister)(SR_LR_SpecialRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   393
#define SR_CTR     ((SpecialRegister)(SR_CTR_SpecialRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   394
#define SR_VRSAVE  ((SpecialRegister)(SR_VRSAVE_SpecialRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   395
#define SR_SPEFSCR ((SpecialRegister)(SR_SPEFSCR_SpecialRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   396
#define SR_PPR     ((SpecialRegister)(SR_PPR_SpecialRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   397
#endif // DONT_USE_REGISTER_DEFINES
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   398
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   399
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   400
// Use VectorRegister as shortcut
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   401
class VectorRegisterImpl;
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   402
typedef VectorRegisterImpl* VectorRegister;
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   403
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   404
inline VectorRegister as_VectorRegister(int encoding) {
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   405
  return (VectorRegister)(intptr_t)encoding;
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   406
}
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   407
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   408
// The implementation of vector registers for the Power architecture
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   409
class VectorRegisterImpl: public AbstractRegisterImpl {
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   410
 public:
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   411
  enum {
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   412
    number_of_registers = 32
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   413
  };
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   414
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   415
  // construction
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   416
  inline friend VectorRegister as_VectorRegister(int encoding);
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   417
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   418
  // accessors
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   419
  int            encoding()  const { assert(is_valid(), "invalid register"); return value(); }
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   420
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   421
  // testers
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   422
  bool is_valid()       const { return   0 <=  value()       &&  value() < number_of_registers; }
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   423
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   424
  const char* name() const;
46809
057f21a10f5f 8185969: PPC64: Improve VSR support to use up to 64 registers
mdoerr
parents: 40071
diff changeset
   425
057f21a10f5f 8185969: PPC64: Improve VSR support to use up to 64 registers
mdoerr
parents: 40071
diff changeset
   426
  // convert to VSR
057f21a10f5f 8185969: PPC64: Improve VSR support to use up to 64 registers
mdoerr
parents: 40071
diff changeset
   427
  VectorSRegister to_vsr() const;
22824
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   428
};
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   429
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   430
// The Vector registers of the Power architecture
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   431
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   432
CONSTANT_REGISTER_DECLARATION(VectorRegister, vnoreg, (-1));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   433
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   434
CONSTANT_REGISTER_DECLARATION(VectorRegister, VR0,  ( 0));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   435
CONSTANT_REGISTER_DECLARATION(VectorRegister, VR1,  ( 1));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   436
CONSTANT_REGISTER_DECLARATION(VectorRegister, VR2,  ( 2));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   437
CONSTANT_REGISTER_DECLARATION(VectorRegister, VR3,  ( 3));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   438
CONSTANT_REGISTER_DECLARATION(VectorRegister, VR4,  ( 4));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   439
CONSTANT_REGISTER_DECLARATION(VectorRegister, VR5,  ( 5));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   440
CONSTANT_REGISTER_DECLARATION(VectorRegister, VR6,  ( 6));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   441
CONSTANT_REGISTER_DECLARATION(VectorRegister, VR7,  ( 7));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   442
CONSTANT_REGISTER_DECLARATION(VectorRegister, VR8,  ( 8));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   443
CONSTANT_REGISTER_DECLARATION(VectorRegister, VR9,  ( 9));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   444
CONSTANT_REGISTER_DECLARATION(VectorRegister, VR10, (10));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   445
CONSTANT_REGISTER_DECLARATION(VectorRegister, VR11, (11));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   446
CONSTANT_REGISTER_DECLARATION(VectorRegister, VR12, (12));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   447
CONSTANT_REGISTER_DECLARATION(VectorRegister, VR13, (13));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   448
CONSTANT_REGISTER_DECLARATION(VectorRegister, VR14, (14));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   449
CONSTANT_REGISTER_DECLARATION(VectorRegister, VR15, (15));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   450
CONSTANT_REGISTER_DECLARATION(VectorRegister, VR16, (16));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   451
CONSTANT_REGISTER_DECLARATION(VectorRegister, VR17, (17));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   452
CONSTANT_REGISTER_DECLARATION(VectorRegister, VR18, (18));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   453
CONSTANT_REGISTER_DECLARATION(VectorRegister, VR19, (19));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   454
CONSTANT_REGISTER_DECLARATION(VectorRegister, VR20, (20));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   455
CONSTANT_REGISTER_DECLARATION(VectorRegister, VR21, (21));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   456
CONSTANT_REGISTER_DECLARATION(VectorRegister, VR22, (22));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   457
CONSTANT_REGISTER_DECLARATION(VectorRegister, VR23, (23));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   458
CONSTANT_REGISTER_DECLARATION(VectorRegister, VR24, (24));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   459
CONSTANT_REGISTER_DECLARATION(VectorRegister, VR25, (25));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   460
CONSTANT_REGISTER_DECLARATION(VectorRegister, VR26, (26));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   461
CONSTANT_REGISTER_DECLARATION(VectorRegister, VR27, (27));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   462
CONSTANT_REGISTER_DECLARATION(VectorRegister, VR28, (28));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   463
CONSTANT_REGISTER_DECLARATION(VectorRegister, VR29, (29));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   464
CONSTANT_REGISTER_DECLARATION(VectorRegister, VR30, (30));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   465
CONSTANT_REGISTER_DECLARATION(VectorRegister, VR31, (31));
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   466
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   467
#ifndef DONT_USE_REGISTER_DEFINES
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   468
#define vnoreg ((VectorRegister)(vnoreg_VectorRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   469
#define VR0    ((VectorRegister)(   VR0_VectorRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   470
#define VR1    ((VectorRegister)(   VR1_VectorRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   471
#define VR2    ((VectorRegister)(   VR2_VectorRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   472
#define VR3    ((VectorRegister)(   VR3_VectorRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   473
#define VR4    ((VectorRegister)(   VR4_VectorRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   474
#define VR5    ((VectorRegister)(   VR5_VectorRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   475
#define VR6    ((VectorRegister)(   VR6_VectorRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   476
#define VR7    ((VectorRegister)(   VR7_VectorRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   477
#define VR8    ((VectorRegister)(   VR8_VectorRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   478
#define VR9    ((VectorRegister)(   VR9_VectorRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   479
#define VR10   ((VectorRegister)(  VR10_VectorRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   480
#define VR11   ((VectorRegister)(  VR11_VectorRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   481
#define VR12   ((VectorRegister)(  VR12_VectorRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   482
#define VR13   ((VectorRegister)(  VR13_VectorRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   483
#define VR14   ((VectorRegister)(  VR14_VectorRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   484
#define VR15   ((VectorRegister)(  VR15_VectorRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   485
#define VR16   ((VectorRegister)(  VR16_VectorRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   486
#define VR17   ((VectorRegister)(  VR17_VectorRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   487
#define VR18   ((VectorRegister)(  VR18_VectorRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   488
#define VR19   ((VectorRegister)(  VR19_VectorRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   489
#define VR20   ((VectorRegister)(  VR20_VectorRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   490
#define VR21   ((VectorRegister)(  VR21_VectorRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   491
#define VR22   ((VectorRegister)(  VR22_VectorRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   492
#define VR23   ((VectorRegister)(  VR23_VectorRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   493
#define VR24   ((VectorRegister)(  VR24_VectorRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   494
#define VR25   ((VectorRegister)(  VR25_VectorRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   495
#define VR26   ((VectorRegister)(  VR26_VectorRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   496
#define VR27   ((VectorRegister)(  VR27_VectorRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   497
#define VR28   ((VectorRegister)(  VR28_VectorRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   498
#define VR29   ((VectorRegister)(  VR29_VectorRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   499
#define VR30   ((VectorRegister)(  VR30_VectorRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   500
#define VR31   ((VectorRegister)(  VR31_VectorRegisterEnumValue))
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   501
#endif // DONT_USE_REGISTER_DEFINES
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   502
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   503
39236
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   504
inline VectorSRegister as_VectorSRegister(int encoding) {
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   505
  return (VectorSRegister)(intptr_t)encoding;
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   506
}
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   507
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   508
// The implementation of Vector-Scalar (VSX) registers on POWER architecture.
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   509
class VectorSRegisterImpl: public AbstractRegisterImpl {
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   510
 public:
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   511
  enum {
46809
057f21a10f5f 8185969: PPC64: Improve VSR support to use up to 64 registers
mdoerr
parents: 40071
diff changeset
   512
    number_of_registers = 64
39236
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   513
  };
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   514
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   515
  // construction
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   516
  inline friend VectorSRegister as_VectorSRegister(int encoding);
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   517
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   518
  // accessors
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   519
  int encoding() const { assert(is_valid(), "invalid register"); return value(); }
51710
355bd23b46e5 8210497: [PPC64] Vector registers not saved across safepoint
mdoerr
parents: 47583
diff changeset
   520
  inline VMReg as_VMReg();
39236
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   521
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   522
  // testers
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   523
  bool is_valid() const { return 0 <=  value() &&  value() < number_of_registers; }
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   524
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   525
  const char* name() const;
51711
3aafd7015d87 8208171: PPC64: Enrich SLP support
mhorie
parents: 51710
diff changeset
   526
3aafd7015d87 8208171: PPC64: Enrich SLP support
mhorie
parents: 51710
diff changeset
   527
  // convert to VR
3aafd7015d87 8208171: PPC64: Enrich SLP support
mhorie
parents: 51710
diff changeset
   528
  VectorRegister to_vr() const;
39236
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   529
};
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   530
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   531
// The Vector-Scalar (VSX) registers of the POWER architecture.
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   532
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   533
CONSTANT_REGISTER_DECLARATION(VectorSRegister, vsnoreg, (-1));
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   534
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   535
CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR0,  ( 0));
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   536
CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR1,  ( 1));
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   537
CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR2,  ( 2));
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   538
CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR3,  ( 3));
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   539
CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR4,  ( 4));
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   540
CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR5,  ( 5));
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   541
CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR6,  ( 6));
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   542
CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR7,  ( 7));
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   543
CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR8,  ( 8));
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   544
CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR9,  ( 9));
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   545
CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR10, (10));
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   546
CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR11, (11));
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   547
CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR12, (12));
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   548
CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR13, (13));
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   549
CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR14, (14));
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   550
CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR15, (15));
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   551
CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR16, (16));
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   552
CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR17, (17));
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   553
CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR18, (18));
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   554
CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR19, (19));
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   555
CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR20, (20));
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   556
CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR21, (21));
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   557
CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR22, (22));
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   558
CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR23, (23));
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   559
CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR24, (24));
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   560
CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR25, (25));
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   561
CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR26, (26));
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   562
CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR27, (27));
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   563
CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR28, (28));
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   564
CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR29, (29));
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   565
CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR30, (30));
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   566
CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR31, (31));
46809
057f21a10f5f 8185969: PPC64: Improve VSR support to use up to 64 registers
mdoerr
parents: 40071
diff changeset
   567
CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR32, (32));
057f21a10f5f 8185969: PPC64: Improve VSR support to use up to 64 registers
mdoerr
parents: 40071
diff changeset
   568
CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR33, (33));
057f21a10f5f 8185969: PPC64: Improve VSR support to use up to 64 registers
mdoerr
parents: 40071
diff changeset
   569
CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR34, (34));
057f21a10f5f 8185969: PPC64: Improve VSR support to use up to 64 registers
mdoerr
parents: 40071
diff changeset
   570
CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR35, (35));
057f21a10f5f 8185969: PPC64: Improve VSR support to use up to 64 registers
mdoerr
parents: 40071
diff changeset
   571
CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR36, (36));
057f21a10f5f 8185969: PPC64: Improve VSR support to use up to 64 registers
mdoerr
parents: 40071
diff changeset
   572
CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR37, (37));
057f21a10f5f 8185969: PPC64: Improve VSR support to use up to 64 registers
mdoerr
parents: 40071
diff changeset
   573
CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR38, (38));
057f21a10f5f 8185969: PPC64: Improve VSR support to use up to 64 registers
mdoerr
parents: 40071
diff changeset
   574
CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR39, (39));
057f21a10f5f 8185969: PPC64: Improve VSR support to use up to 64 registers
mdoerr
parents: 40071
diff changeset
   575
CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR40, (40));
057f21a10f5f 8185969: PPC64: Improve VSR support to use up to 64 registers
mdoerr
parents: 40071
diff changeset
   576
CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR41, (41));
057f21a10f5f 8185969: PPC64: Improve VSR support to use up to 64 registers
mdoerr
parents: 40071
diff changeset
   577
CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR42, (42));
057f21a10f5f 8185969: PPC64: Improve VSR support to use up to 64 registers
mdoerr
parents: 40071
diff changeset
   578
CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR43, (43));
057f21a10f5f 8185969: PPC64: Improve VSR support to use up to 64 registers
mdoerr
parents: 40071
diff changeset
   579
CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR44, (44));
057f21a10f5f 8185969: PPC64: Improve VSR support to use up to 64 registers
mdoerr
parents: 40071
diff changeset
   580
CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR45, (45));
057f21a10f5f 8185969: PPC64: Improve VSR support to use up to 64 registers
mdoerr
parents: 40071
diff changeset
   581
CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR46, (46));
057f21a10f5f 8185969: PPC64: Improve VSR support to use up to 64 registers
mdoerr
parents: 40071
diff changeset
   582
CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR47, (47));
057f21a10f5f 8185969: PPC64: Improve VSR support to use up to 64 registers
mdoerr
parents: 40071
diff changeset
   583
CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR48, (48));
057f21a10f5f 8185969: PPC64: Improve VSR support to use up to 64 registers
mdoerr
parents: 40071
diff changeset
   584
CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR49, (49));
057f21a10f5f 8185969: PPC64: Improve VSR support to use up to 64 registers
mdoerr
parents: 40071
diff changeset
   585
CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR50, (50));
057f21a10f5f 8185969: PPC64: Improve VSR support to use up to 64 registers
mdoerr
parents: 40071
diff changeset
   586
CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR51, (51));
057f21a10f5f 8185969: PPC64: Improve VSR support to use up to 64 registers
mdoerr
parents: 40071
diff changeset
   587
CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR52, (52));
057f21a10f5f 8185969: PPC64: Improve VSR support to use up to 64 registers
mdoerr
parents: 40071
diff changeset
   588
CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR53, (53));
057f21a10f5f 8185969: PPC64: Improve VSR support to use up to 64 registers
mdoerr
parents: 40071
diff changeset
   589
CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR54, (54));
057f21a10f5f 8185969: PPC64: Improve VSR support to use up to 64 registers
mdoerr
parents: 40071
diff changeset
   590
CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR55, (55));
057f21a10f5f 8185969: PPC64: Improve VSR support to use up to 64 registers
mdoerr
parents: 40071
diff changeset
   591
CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR56, (56));
057f21a10f5f 8185969: PPC64: Improve VSR support to use up to 64 registers
mdoerr
parents: 40071
diff changeset
   592
CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR57, (57));
057f21a10f5f 8185969: PPC64: Improve VSR support to use up to 64 registers
mdoerr
parents: 40071
diff changeset
   593
CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR58, (58));
057f21a10f5f 8185969: PPC64: Improve VSR support to use up to 64 registers
mdoerr
parents: 40071
diff changeset
   594
CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR59, (59));
057f21a10f5f 8185969: PPC64: Improve VSR support to use up to 64 registers
mdoerr
parents: 40071
diff changeset
   595
CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR60, (60));
057f21a10f5f 8185969: PPC64: Improve VSR support to use up to 64 registers
mdoerr
parents: 40071
diff changeset
   596
CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR61, (61));
057f21a10f5f 8185969: PPC64: Improve VSR support to use up to 64 registers
mdoerr
parents: 40071
diff changeset
   597
CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR62, (62));
057f21a10f5f 8185969: PPC64: Improve VSR support to use up to 64 registers
mdoerr
parents: 40071
diff changeset
   598
CONSTANT_REGISTER_DECLARATION(VectorSRegister, VSR63, (63));
39236
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   599
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   600
#ifndef DONT_USE_REGISTER_DEFINES
51711
3aafd7015d87 8208171: PPC64: Enrich SLP support
mhorie
parents: 51710
diff changeset
   601
#define vsnoreg ((VectorSRegister)(vsnoreg_VectorSRegisterEnumValue))
39236
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   602
#define VSR0    ((VectorSRegister)(   VSR0_VectorSRegisterEnumValue))
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   603
#define VSR1    ((VectorSRegister)(   VSR1_VectorSRegisterEnumValue))
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   604
#define VSR2    ((VectorSRegister)(   VSR2_VectorSRegisterEnumValue))
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   605
#define VSR3    ((VectorSRegister)(   VSR3_VectorSRegisterEnumValue))
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   606
#define VSR4    ((VectorSRegister)(   VSR4_VectorSRegisterEnumValue))
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   607
#define VSR5    ((VectorSRegister)(   VSR5_VectorSRegisterEnumValue))
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   608
#define VSR6    ((VectorSRegister)(   VSR6_VectorSRegisterEnumValue))
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   609
#define VSR7    ((VectorSRegister)(   VSR7_VectorSRegisterEnumValue))
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   610
#define VSR8    ((VectorSRegister)(   VSR8_VectorSRegisterEnumValue))
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   611
#define VSR9    ((VectorSRegister)(   VSR9_VectorSRegisterEnumValue))
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   612
#define VSR10   ((VectorSRegister)(  VSR10_VectorSRegisterEnumValue))
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   613
#define VSR11   ((VectorSRegister)(  VSR11_VectorSRegisterEnumValue))
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   614
#define VSR12   ((VectorSRegister)(  VSR12_VectorSRegisterEnumValue))
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   615
#define VSR13   ((VectorSRegister)(  VSR13_VectorSRegisterEnumValue))
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   616
#define VSR14   ((VectorSRegister)(  VSR14_VectorSRegisterEnumValue))
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   617
#define VSR15   ((VectorSRegister)(  VSR15_VectorSRegisterEnumValue))
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   618
#define VSR16   ((VectorSRegister)(  VSR16_VectorSRegisterEnumValue))
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   619
#define VSR17   ((VectorSRegister)(  VSR17_VectorSRegisterEnumValue))
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   620
#define VSR18   ((VectorSRegister)(  VSR18_VectorSRegisterEnumValue))
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   621
#define VSR19   ((VectorSRegister)(  VSR19_VectorSRegisterEnumValue))
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   622
#define VSR20   ((VectorSRegister)(  VSR20_VectorSRegisterEnumValue))
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   623
#define VSR21   ((VectorSRegister)(  VSR21_VectorSRegisterEnumValue))
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   624
#define VSR22   ((VectorSRegister)(  VSR22_VectorSRegisterEnumValue))
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   625
#define VSR23   ((VectorSRegister)(  VSR23_VectorSRegisterEnumValue))
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   626
#define VSR24   ((VectorSRegister)(  VSR24_VectorSRegisterEnumValue))
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   627
#define VSR25   ((VectorSRegister)(  VSR25_VectorSRegisterEnumValue))
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   628
#define VSR26   ((VectorSRegister)(  VSR26_VectorSRegisterEnumValue))
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   629
#define VSR27   ((VectorSRegister)(  VSR27_VectorSRegisterEnumValue))
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   630
#define VSR28   ((VectorSRegister)(  VSR28_VectorSRegisterEnumValue))
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   631
#define VSR29   ((VectorSRegister)(  VSR29_VectorSRegisterEnumValue))
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   632
#define VSR30   ((VectorSRegister)(  VSR30_VectorSRegisterEnumValue))
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   633
#define VSR31   ((VectorSRegister)(  VSR31_VectorSRegisterEnumValue))
46809
057f21a10f5f 8185969: PPC64: Improve VSR support to use up to 64 registers
mdoerr
parents: 40071
diff changeset
   634
#define VSR32   ((VectorSRegister)(  VSR32_VectorSRegisterEnumValue))
057f21a10f5f 8185969: PPC64: Improve VSR support to use up to 64 registers
mdoerr
parents: 40071
diff changeset
   635
#define VSR33   ((VectorSRegister)(  VSR33_VectorSRegisterEnumValue))
057f21a10f5f 8185969: PPC64: Improve VSR support to use up to 64 registers
mdoerr
parents: 40071
diff changeset
   636
#define VSR34   ((VectorSRegister)(  VSR34_VectorSRegisterEnumValue))
057f21a10f5f 8185969: PPC64: Improve VSR support to use up to 64 registers
mdoerr
parents: 40071
diff changeset
   637
#define VSR35   ((VectorSRegister)(  VSR35_VectorSRegisterEnumValue))
057f21a10f5f 8185969: PPC64: Improve VSR support to use up to 64 registers
mdoerr
parents: 40071
diff changeset
   638
#define VSR36   ((VectorSRegister)(  VSR36_VectorSRegisterEnumValue))
057f21a10f5f 8185969: PPC64: Improve VSR support to use up to 64 registers
mdoerr
parents: 40071
diff changeset
   639
#define VSR37   ((VectorSRegister)(  VSR37_VectorSRegisterEnumValue))
057f21a10f5f 8185969: PPC64: Improve VSR support to use up to 64 registers
mdoerr
parents: 40071
diff changeset
   640
#define VSR38   ((VectorSRegister)(  VSR38_VectorSRegisterEnumValue))
057f21a10f5f 8185969: PPC64: Improve VSR support to use up to 64 registers
mdoerr
parents: 40071
diff changeset
   641
#define VSR39   ((VectorSRegister)(  VSR39_VectorSRegisterEnumValue))
057f21a10f5f 8185969: PPC64: Improve VSR support to use up to 64 registers
mdoerr
parents: 40071
diff changeset
   642
#define VSR40   ((VectorSRegister)(  VSR40_VectorSRegisterEnumValue))
057f21a10f5f 8185969: PPC64: Improve VSR support to use up to 64 registers
mdoerr
parents: 40071
diff changeset
   643
#define VSR41   ((VectorSRegister)(  VSR41_VectorSRegisterEnumValue))
057f21a10f5f 8185969: PPC64: Improve VSR support to use up to 64 registers
mdoerr
parents: 40071
diff changeset
   644
#define VSR42   ((VectorSRegister)(  VSR42_VectorSRegisterEnumValue))
057f21a10f5f 8185969: PPC64: Improve VSR support to use up to 64 registers
mdoerr
parents: 40071
diff changeset
   645
#define VSR43   ((VectorSRegister)(  VSR43_VectorSRegisterEnumValue))
057f21a10f5f 8185969: PPC64: Improve VSR support to use up to 64 registers
mdoerr
parents: 40071
diff changeset
   646
#define VSR44   ((VectorSRegister)(  VSR44_VectorSRegisterEnumValue))
057f21a10f5f 8185969: PPC64: Improve VSR support to use up to 64 registers
mdoerr
parents: 40071
diff changeset
   647
#define VSR45   ((VectorSRegister)(  VSR45_VectorSRegisterEnumValue))
057f21a10f5f 8185969: PPC64: Improve VSR support to use up to 64 registers
mdoerr
parents: 40071
diff changeset
   648
#define VSR46   ((VectorSRegister)(  VSR46_VectorSRegisterEnumValue))
057f21a10f5f 8185969: PPC64: Improve VSR support to use up to 64 registers
mdoerr
parents: 40071
diff changeset
   649
#define VSR47   ((VectorSRegister)(  VSR47_VectorSRegisterEnumValue))
057f21a10f5f 8185969: PPC64: Improve VSR support to use up to 64 registers
mdoerr
parents: 40071
diff changeset
   650
#define VSR48   ((VectorSRegister)(  VSR48_VectorSRegisterEnumValue))
057f21a10f5f 8185969: PPC64: Improve VSR support to use up to 64 registers
mdoerr
parents: 40071
diff changeset
   651
#define VSR49   ((VectorSRegister)(  VSR49_VectorSRegisterEnumValue))
057f21a10f5f 8185969: PPC64: Improve VSR support to use up to 64 registers
mdoerr
parents: 40071
diff changeset
   652
#define VSR50   ((VectorSRegister)(  VSR50_VectorSRegisterEnumValue))
057f21a10f5f 8185969: PPC64: Improve VSR support to use up to 64 registers
mdoerr
parents: 40071
diff changeset
   653
#define VSR51   ((VectorSRegister)(  VSR51_VectorSRegisterEnumValue))
057f21a10f5f 8185969: PPC64: Improve VSR support to use up to 64 registers
mdoerr
parents: 40071
diff changeset
   654
#define VSR52   ((VectorSRegister)(  VSR52_VectorSRegisterEnumValue))
057f21a10f5f 8185969: PPC64: Improve VSR support to use up to 64 registers
mdoerr
parents: 40071
diff changeset
   655
#define VSR53   ((VectorSRegister)(  VSR53_VectorSRegisterEnumValue))
057f21a10f5f 8185969: PPC64: Improve VSR support to use up to 64 registers
mdoerr
parents: 40071
diff changeset
   656
#define VSR54   ((VectorSRegister)(  VSR54_VectorSRegisterEnumValue))
057f21a10f5f 8185969: PPC64: Improve VSR support to use up to 64 registers
mdoerr
parents: 40071
diff changeset
   657
#define VSR55   ((VectorSRegister)(  VSR55_VectorSRegisterEnumValue))
057f21a10f5f 8185969: PPC64: Improve VSR support to use up to 64 registers
mdoerr
parents: 40071
diff changeset
   658
#define VSR56   ((VectorSRegister)(  VSR56_VectorSRegisterEnumValue))
057f21a10f5f 8185969: PPC64: Improve VSR support to use up to 64 registers
mdoerr
parents: 40071
diff changeset
   659
#define VSR57   ((VectorSRegister)(  VSR57_VectorSRegisterEnumValue))
057f21a10f5f 8185969: PPC64: Improve VSR support to use up to 64 registers
mdoerr
parents: 40071
diff changeset
   660
#define VSR58   ((VectorSRegister)(  VSR58_VectorSRegisterEnumValue))
057f21a10f5f 8185969: PPC64: Improve VSR support to use up to 64 registers
mdoerr
parents: 40071
diff changeset
   661
#define VSR59   ((VectorSRegister)(  VSR59_VectorSRegisterEnumValue))
057f21a10f5f 8185969: PPC64: Improve VSR support to use up to 64 registers
mdoerr
parents: 40071
diff changeset
   662
#define VSR60   ((VectorSRegister)(  VSR60_VectorSRegisterEnumValue))
057f21a10f5f 8185969: PPC64: Improve VSR support to use up to 64 registers
mdoerr
parents: 40071
diff changeset
   663
#define VSR61   ((VectorSRegister)(  VSR61_VectorSRegisterEnumValue))
057f21a10f5f 8185969: PPC64: Improve VSR support to use up to 64 registers
mdoerr
parents: 40071
diff changeset
   664
#define VSR62   ((VectorSRegister)(  VSR62_VectorSRegisterEnumValue))
057f21a10f5f 8185969: PPC64: Improve VSR support to use up to 64 registers
mdoerr
parents: 40071
diff changeset
   665
#define VSR63   ((VectorSRegister)(  VSR63_VectorSRegisterEnumValue))
39236
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   666
#endif // DONT_USE_REGISTER_DEFINES
c9d756fa846e 8154156: PPC64: improve array copy stubs by using vector instructions
mdoerr
parents: 35594
diff changeset
   667
22824
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   668
// Maximum number of incoming arguments that can be passed in i registers.
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   669
const int PPC_ARGS_IN_REGS_NUM = 8;
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   670
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   671
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   672
// Need to know the total number of registers of all sorts for SharedInfo.
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   673
// Define a class that exports it.
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   674
class ConcreteRegisterImpl : public AbstractRegisterImpl {
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   675
 public:
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   676
  enum {
51710
355bd23b46e5 8210497: [PPC64] Vector registers not saved across safepoint
mdoerr
parents: 47583
diff changeset
   677
    max_gpr = RegisterImpl::number_of_registers * 2,
355bd23b46e5 8210497: [PPC64] Vector registers not saved across safepoint
mdoerr
parents: 47583
diff changeset
   678
    max_fpr = max_gpr + FloatRegisterImpl::number_of_registers * 2,
355bd23b46e5 8210497: [PPC64] Vector registers not saved across safepoint
mdoerr
parents: 47583
diff changeset
   679
    max_vsr = max_fpr + VectorSRegisterImpl::number_of_registers,
355bd23b46e5 8210497: [PPC64] Vector registers not saved across safepoint
mdoerr
parents: 47583
diff changeset
   680
    max_cnd = max_vsr + ConditionRegisterImpl::number_of_registers,
355bd23b46e5 8210497: [PPC64] Vector registers not saved across safepoint
mdoerr
parents: 47583
diff changeset
   681
    max_spr = max_cnd + SpecialRegisterImpl::number_of_registers,
22824
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   682
    // This number must be large enough to cover REG_COUNT (defined by c2) registers.
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   683
    // There is no requirement that any ordering here matches any ordering c2 gives
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   684
    // it's optoregs.
51710
355bd23b46e5 8210497: [PPC64] Vector registers not saved across safepoint
mdoerr
parents: 47583
diff changeset
   685
    number_of_registers = max_spr
22824
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   686
  };
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   687
};
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   688
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   689
// Common register declarations used in assembler code.
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   690
REGISTER_DECLARATION(Register,      R0_SCRATCH, R0);  // volatile
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   691
REGISTER_DECLARATION(Register,      R1_SP,      R1);  // non-volatile
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   692
REGISTER_DECLARATION(Register,      R2_TOC,     R2);  // volatile
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   693
REGISTER_DECLARATION(Register,      R3_RET,     R3);  // volatile
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   694
REGISTER_DECLARATION(Register,      R3_ARG1,    R3);  // volatile
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   695
REGISTER_DECLARATION(Register,      R4_ARG2,    R4);  // volatile
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   696
REGISTER_DECLARATION(Register,      R5_ARG3,    R5);  // volatile
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   697
REGISTER_DECLARATION(Register,      R6_ARG4,    R6);  // volatile
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   698
REGISTER_DECLARATION(Register,      R7_ARG5,    R7);  // volatile
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   699
REGISTER_DECLARATION(Register,      R8_ARG6,    R8);  // volatile
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   700
REGISTER_DECLARATION(Register,      R9_ARG7,    R9);  // volatile
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   701
REGISTER_DECLARATION(Register,      R10_ARG8,   R10); // volatile
22861
f5c393d456fc 8029940: PPC64 (part 122): C2 compiler port
goetz
parents: 22824
diff changeset
   702
REGISTER_DECLARATION(FloatRegister, F0_SCRATCH, F0);  // volatile
22824
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   703
REGISTER_DECLARATION(FloatRegister, F1_RET,     F1);  // volatile
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   704
REGISTER_DECLARATION(FloatRegister, F1_ARG1,    F1);  // volatile
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   705
REGISTER_DECLARATION(FloatRegister, F2_ARG2,    F2);  // volatile
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   706
REGISTER_DECLARATION(FloatRegister, F3_ARG3,    F3);  // volatile
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   707
REGISTER_DECLARATION(FloatRegister, F4_ARG4,    F4);  // volatile
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   708
REGISTER_DECLARATION(FloatRegister, F5_ARG5,    F5);  // volatile
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   709
REGISTER_DECLARATION(FloatRegister, F6_ARG6,    F6);  // volatile
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   710
REGISTER_DECLARATION(FloatRegister, F7_ARG7,    F7);  // volatile
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   711
REGISTER_DECLARATION(FloatRegister, F8_ARG8,    F8);  // volatile
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   712
REGISTER_DECLARATION(FloatRegister, F9_ARG9,    F9);  // volatile
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   713
REGISTER_DECLARATION(FloatRegister, F10_ARG10,  F10); // volatile
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   714
REGISTER_DECLARATION(FloatRegister, F11_ARG11,  F11); // volatile
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   715
REGISTER_DECLARATION(FloatRegister, F12_ARG12,  F12); // volatile
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   716
REGISTER_DECLARATION(FloatRegister, F13_ARG13,  F13); // volatile
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   717
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   718
#ifndef DONT_USE_REGISTER_DEFINES
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   719
#define R0_SCRATCH         AS_REGISTER(Register, R0)
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   720
#define R1_SP              AS_REGISTER(Register, R1)
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   721
#define R2_TOC             AS_REGISTER(Register, R2)
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   722
#define R3_RET             AS_REGISTER(Register, R3)
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   723
#define R3_ARG1            AS_REGISTER(Register, R3)
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   724
#define R4_ARG2            AS_REGISTER(Register, R4)
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   725
#define R5_ARG3            AS_REGISTER(Register, R5)
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   726
#define R6_ARG4            AS_REGISTER(Register, R6)
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   727
#define R7_ARG5            AS_REGISTER(Register, R7)
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   728
#define R8_ARG6            AS_REGISTER(Register, R8)
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   729
#define R9_ARG7            AS_REGISTER(Register, R9)
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   730
#define R10_ARG8           AS_REGISTER(Register, R10)
22861
f5c393d456fc 8029940: PPC64 (part 122): C2 compiler port
goetz
parents: 22824
diff changeset
   731
#define F0_SCRATCH         AS_REGISTER(FloatRegister, F0)
22824
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   732
#define F1_RET             AS_REGISTER(FloatRegister, F1)
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   733
#define F1_ARG1            AS_REGISTER(FloatRegister, F1)
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   734
#define F2_ARG2            AS_REGISTER(FloatRegister, F2)
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   735
#define F3_ARG3            AS_REGISTER(FloatRegister, F3)
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   736
#define F4_ARG4            AS_REGISTER(FloatRegister, F4)
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   737
#define F5_ARG5            AS_REGISTER(FloatRegister, F5)
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   738
#define F6_ARG6            AS_REGISTER(FloatRegister, F6)
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   739
#define F7_ARG7            AS_REGISTER(FloatRegister, F7)
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   740
#define F8_ARG8            AS_REGISTER(FloatRegister, F8)
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   741
#define F9_ARG9            AS_REGISTER(FloatRegister, F9)
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   742
#define F10_ARG10          AS_REGISTER(FloatRegister, F10)
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   743
#define F11_ARG11          AS_REGISTER(FloatRegister, F11)
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   744
#define F12_ARG12          AS_REGISTER(FloatRegister, F12)
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   745
#define F13_ARG13          AS_REGISTER(FloatRegister, F13)
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   746
#endif
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   747
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   748
// Register declarations to be used in frame manager assembly code.
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   749
// Use only non-volatile registers in order to keep values across C-calls.
23221
b70675ece1ce 8036976: PPC64: implement the template interpreter
goetz
parents: 22861
diff changeset
   750
REGISTER_DECLARATION(Register, R14_bcp,        R14);
b70675ece1ce 8036976: PPC64: implement the template interpreter
goetz
parents: 22861
diff changeset
   751
REGISTER_DECLARATION(Register, R15_esp,        R15);
b70675ece1ce 8036976: PPC64: implement the template interpreter
goetz
parents: 22861
diff changeset
   752
REGISTER_DECLARATION(FloatRegister, F15_ftos,  F15);
22824
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   753
REGISTER_DECLARATION(Register, R16_thread,     R16);      // address of current thread
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   754
REGISTER_DECLARATION(Register, R17_tos,        R17);      // address of Java tos (prepushed).
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   755
REGISTER_DECLARATION(Register, R18_locals,     R18);      // address of first param slot (receiver).
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   756
REGISTER_DECLARATION(Register, R19_method,     R19);      // address of current method
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   757
#ifndef DONT_USE_REGISTER_DEFINES
23221
b70675ece1ce 8036976: PPC64: implement the template interpreter
goetz
parents: 22861
diff changeset
   758
#define R14_bcp           AS_REGISTER(Register, R14)
b70675ece1ce 8036976: PPC64: implement the template interpreter
goetz
parents: 22861
diff changeset
   759
#define R15_esp           AS_REGISTER(Register, R15)
b70675ece1ce 8036976: PPC64: implement the template interpreter
goetz
parents: 22861
diff changeset
   760
#define F15_ftos          AS_REGISTER(FloatRegister, F15)
22824
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   761
#define R16_thread        AS_REGISTER(Register, R16)
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   762
#define R17_tos           AS_REGISTER(Register, R17)
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   763
#define R18_locals        AS_REGISTER(Register, R18)
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   764
#define R19_method        AS_REGISTER(Register, R19)
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   765
#define R21_sender_SP     AS_REGISTER(Register, R21)
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   766
#define R23_method_handle AS_REGISTER(Register, R23)
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   767
#endif
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   768
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   769
// Temporary registers to be used within frame manager. We can use
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   770
// the non-volatiles because the call stub has saved them.
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   771
// Use only non-volatile registers in order to keep values across C-calls.
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   772
REGISTER_DECLARATION(Register, R21_tmp1, R21);
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   773
REGISTER_DECLARATION(Register, R22_tmp2, R22);
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   774
REGISTER_DECLARATION(Register, R23_tmp3, R23);
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   775
REGISTER_DECLARATION(Register, R24_tmp4, R24);
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   776
REGISTER_DECLARATION(Register, R25_tmp5, R25);
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   777
REGISTER_DECLARATION(Register, R26_tmp6, R26);
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   778
REGISTER_DECLARATION(Register, R27_tmp7, R27);
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   779
REGISTER_DECLARATION(Register, R28_tmp8, R28);
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   780
REGISTER_DECLARATION(Register, R29_tmp9, R29);
23221
b70675ece1ce 8036976: PPC64: implement the template interpreter
goetz
parents: 22861
diff changeset
   781
REGISTER_DECLARATION(Register, R24_dispatch_addr,     R24);
b70675ece1ce 8036976: PPC64: implement the template interpreter
goetz
parents: 22861
diff changeset
   782
REGISTER_DECLARATION(Register, R25_templateTableBase, R25);
b70675ece1ce 8036976: PPC64: implement the template interpreter
goetz
parents: 22861
diff changeset
   783
REGISTER_DECLARATION(Register, R26_monitor,           R26);
b70675ece1ce 8036976: PPC64: implement the template interpreter
goetz
parents: 22861
diff changeset
   784
REGISTER_DECLARATION(Register, R27_constPoolCache,    R27);
b70675ece1ce 8036976: PPC64: implement the template interpreter
goetz
parents: 22861
diff changeset
   785
REGISTER_DECLARATION(Register, R28_mdx,               R28);
b70675ece1ce 8036976: PPC64: implement the template interpreter
goetz
parents: 22861
diff changeset
   786
35085
839c8ba29724 8144019: PPC64 C1: Introduce Client Compiler
mdoerr
parents: 25715
diff changeset
   787
REGISTER_DECLARATION(Register, R19_inline_cache_reg, R19);
839c8ba29724 8144019: PPC64 C1: Introduce Client Compiler
mdoerr
parents: 25715
diff changeset
   788
REGISTER_DECLARATION(Register, R29_TOC, R29);
839c8ba29724 8144019: PPC64 C1: Introduce Client Compiler
mdoerr
parents: 25715
diff changeset
   789
22824
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   790
#ifndef DONT_USE_REGISTER_DEFINES
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   791
#define R21_tmp1         AS_REGISTER(Register, R21)
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   792
#define R22_tmp2         AS_REGISTER(Register, R22)
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   793
#define R23_tmp3         AS_REGISTER(Register, R23)
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   794
#define R24_tmp4         AS_REGISTER(Register, R24)
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   795
#define R25_tmp5         AS_REGISTER(Register, R25)
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   796
#define R26_tmp6         AS_REGISTER(Register, R26)
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   797
#define R27_tmp7         AS_REGISTER(Register, R27)
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   798
#define R28_tmp8         AS_REGISTER(Register, R28)
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   799
#define R29_tmp9         AS_REGISTER(Register, R29)
23221
b70675ece1ce 8036976: PPC64: implement the template interpreter
goetz
parents: 22861
diff changeset
   800
//    Lmonitors  : monitor pointer
b70675ece1ce 8036976: PPC64: implement the template interpreter
goetz
parents: 22861
diff changeset
   801
//    LcpoolCache: constant pool cache
b70675ece1ce 8036976: PPC64: implement the template interpreter
goetz
parents: 22861
diff changeset
   802
//    mdx: method data index
b70675ece1ce 8036976: PPC64: implement the template interpreter
goetz
parents: 22861
diff changeset
   803
#define R24_dispatch_addr     AS_REGISTER(Register, R24)
b70675ece1ce 8036976: PPC64: implement the template interpreter
goetz
parents: 22861
diff changeset
   804
#define R25_templateTableBase AS_REGISTER(Register, R25)
b70675ece1ce 8036976: PPC64: implement the template interpreter
goetz
parents: 22861
diff changeset
   805
#define R26_monitor           AS_REGISTER(Register, R26)
b70675ece1ce 8036976: PPC64: implement the template interpreter
goetz
parents: 22861
diff changeset
   806
#define R27_constPoolCache    AS_REGISTER(Register, R27)
b70675ece1ce 8036976: PPC64: implement the template interpreter
goetz
parents: 22861
diff changeset
   807
#define R28_mdx               AS_REGISTER(Register, R28)
22824
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   808
35085
839c8ba29724 8144019: PPC64 C1: Introduce Client Compiler
mdoerr
parents: 25715
diff changeset
   809
#define R19_inline_cache_reg AS_REGISTER(Register, R19)
839c8ba29724 8144019: PPC64 C1: Introduce Client Compiler
mdoerr
parents: 25715
diff changeset
   810
#define R29_TOC AS_REGISTER(Register, R29)
22824
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   811
#endif
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   812
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   813
// Scratch registers are volatile.
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   814
REGISTER_DECLARATION(Register, R11_scratch1, R11);
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   815
REGISTER_DECLARATION(Register, R12_scratch2, R12);
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   816
#ifndef DONT_USE_REGISTER_DEFINES
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   817
#define R11_scratch1   AS_REGISTER(Register, R11)
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   818
#define R12_scratch2   AS_REGISTER(Register, R12)
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   819
#endif
28258dd5cb2e 8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff changeset
   820
53244
9807daeb47c4 8216167: Update include guards to reflect correct directories
coleenp
parents: 51777
diff changeset
   821
#endif // CPU_PPC_REGISTER_PPC_HPP