src/hotspot/cpu/s390/registerSaver_s390.hpp
author coleenp
Thu, 10 Jan 2019 15:13:51 -0500
changeset 53244 9807daeb47c4
parent 47216 71c04702a3d5
permissions -rw-r--r--
8216167: Update include guards to reflect correct directories Summary: Use script and some manual fixup to fix directores names in include guards. Reviewed-by: lfoltan, eosterlund, kbarrett
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
42065
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
     1
/*
53244
9807daeb47c4 8216167: Update include guards to reflect correct directories
coleenp
parents: 47216
diff changeset
     2
 * Copyright (c) 2016, 2019, Oracle and/or its affiliates. All rights reserved.
42065
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
     3
 * Copyright (c) 2016 SAP SE. All rights reserved.
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
     4
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
     5
 *
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
     6
 * This code is free software; you can redistribute it and/or modify it
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
     7
 * under the terms of the GNU General Public License version 2 only, as
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
     8
 * published by the Free Software Foundation.
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
     9
 *
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
    10
 * This code is distributed in the hope that it will be useful, but WITHOUT
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
    11
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
    12
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
    13
 * version 2 for more details (a copy is included in the LICENSE file that
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
    14
 * accompanied this code).
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
    15
 *
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
    16
 * You should have received a copy of the GNU General Public License version
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
    17
 * 2 along with this work; if not, write to the Free Software Foundation,
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
    18
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
    19
 *
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
    20
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
    21
 * or visit www.oracle.com if you need additional information or have any
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
    22
 * questions.
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
    23
 *
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
    24
 */
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
    25
53244
9807daeb47c4 8216167: Update include guards to reflect correct directories
coleenp
parents: 47216
diff changeset
    26
#ifndef CPU_S390_REGISTERSAVER_S390_HPP
9807daeb47c4 8216167: Update include guards to reflect correct directories
coleenp
parents: 47216
diff changeset
    27
#define CPU_S390_REGISTERSAVER_S390_HPP
42065
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
    28
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
    29
class RegisterSaver {
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
    30
  // Used for saving volatile registers.
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
    31
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
    32
  // Class declaration moved to separate file to make it available elsewhere.
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
    33
  // Implementation remains in sharedRuntime_s390.cpp
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
    34
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
    35
 public:
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
    36
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
    37
  // Set of registers to be saved.
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
    38
  typedef enum {
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
    39
    all_registers,
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
    40
    all_registers_except_r2,
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
    41
    all_integer_registers,
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
    42
    all_volatile_registers, // According to ABI calling convention.
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
    43
    arg_registers
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
    44
  } RegisterSet;
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
    45
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
    46
  // Boolean flags to force only argument registers to be saved.
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
    47
  static int live_reg_save_size(RegisterSet reg_set);
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
    48
  static int live_reg_frame_size(RegisterSet reg_set);
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
    49
  // Specify the register that should be stored as the return pc in the current frame.
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
    50
  static OopMap* save_live_registers(MacroAssembler* masm, RegisterSet reg_set, Register return_pc = Z_R14);
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
    51
  static void restore_live_registers(MacroAssembler* masm, RegisterSet reg_set);
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
    52
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
    53
  // Generate the OopMap (again, regs where saved before).
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
    54
  static OopMap* generate_oop_map(MacroAssembler* masm, RegisterSet reg_set);
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
    55
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
    56
  // During deoptimization only the result register need to be restored
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
    57
  // all the other values have already been extracted.
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
    58
  static void restore_result_registers(MacroAssembler* masm);
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
    59
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
    60
  // Constants and data structures:
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
    61
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
    62
  typedef enum {
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
    63
    int_reg           = 0,
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
    64
    float_reg         = 1,
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
    65
    excluded_reg      = 2,  // Not saved/restored.
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
    66
  } RegisterType;
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
    67
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
    68
  typedef enum {
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
    69
    reg_size          = 8,
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
    70
    half_reg_size     = reg_size / 2,
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
    71
  } RegisterConstants;
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
    72
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
    73
  // Remember type, number, and VMReg.
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
    74
  typedef struct {
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
    75
    RegisterType        reg_type;
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
    76
    int                 reg_num;
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
    77
    VMReg               vmreg;
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
    78
  } LiveRegType;
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
    79
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
    80
};
6032b31e3719 8167673: [s390] The s390 port.
goetz
parents:
diff changeset
    81
53244
9807daeb47c4 8216167: Update include guards to reflect correct directories
coleenp
parents: 47216
diff changeset
    82
#endif // CPU_S390_REGISTERSAVER_S390_HPP