hotspot/test/compiler/jvmci/code/amd64/AMD64TestAssembler.java
author rschatz
Wed, 03 Feb 2016 12:16:44 +0100
changeset 35823 59a847ec6ee3
parent 35595 4308ac6d1b16
child 35844 8a1952516600
permissions -rw-r--r--
8146608: [JVMCI] DebugInfo Tests on DeoptimizeALot runs fails in assert(_pc == *pc_addr || pc == *pc_addr) frame::patch_pc() /frame_x86.cpp:285 Reviewed-by: twisti
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
35137
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
     1
/*
35582
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
     2
 * Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved.
35137
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
     4
 *
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
     7
 * published by the Free Software Foundation.
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
     8
 *
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
     9
 * This code is distributed in the hope that it will be useful, but WITHOUT
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
    10
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
    11
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
    12
 * version 2 for more details (a copy is included in the LICENSE file that
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
    13
 * accompanied this code).
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
    14
 *
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
    15
 * You should have received a copy of the GNU General Public License version
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
    16
 * 2 along with this work; if not, write to the Free Software Foundation,
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
    17
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
    18
 *
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
    19
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
    20
 * or visit www.oracle.com if you need additional information or have any
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
    21
 * questions.
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
    22
 */
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
    23
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
    24
package compiler.jvmci.code.amd64;
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
    25
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
    26
import jdk.vm.ci.amd64.AMD64;
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
    27
import jdk.vm.ci.amd64.AMD64Kind;
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
    28
import jdk.vm.ci.code.CodeCacheProvider;
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
    29
import jdk.vm.ci.code.DebugInfo;
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
    30
import jdk.vm.ci.code.Register;
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
    31
import jdk.vm.ci.code.StackSlot;
35582
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
    32
import jdk.vm.ci.code.site.ConstantReference;
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
    33
import jdk.vm.ci.code.site.DataSectionReference;
35595
4308ac6d1b16 8148101: [JVMCI] Make CallingConvention.Type extensible
never
parents: 35583
diff changeset
    34
import jdk.vm.ci.hotspot.HotSpotCallingConventionType;
35137
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
    35
import jdk.vm.ci.hotspot.HotSpotConstant;
35144
f2381983e98e 8146100: compiler/jvmci/code/SimpleCodeInstallationTest.java JUnit Failure: expected:<12> but was:<109710641>
twisti
parents: 35137
diff changeset
    36
import jdk.vm.ci.meta.JavaKind;
35137
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
    37
import jdk.vm.ci.meta.LIRKind;
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
    38
import jdk.vm.ci.meta.VMConstant;
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
    39
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
    40
import compiler.jvmci.code.TestAssembler;
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
    41
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
    42
public class AMD64TestAssembler extends TestAssembler {
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
    43
35582
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
    44
    public AMD64TestAssembler(CodeCacheProvider codeCache) {
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
    45
        super(codeCache, 16, 16, AMD64Kind.DWORD, AMD64.rax, AMD64.rcx, AMD64.rdi, AMD64.r8, AMD64.r9, AMD64.r10);
35137
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
    46
    }
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
    47
35583
3e83096ee8e5 8147475: compiler/jvmci/code/SimpleDebugInfoTest.java fails in Assembler::locate_operand: ShouldNotReachHere()
rschatz
parents: 35582
diff changeset
    48
    private void emitFatNop() {
3e83096ee8e5 8147475: compiler/jvmci/code/SimpleDebugInfoTest.java fails in Assembler::locate_operand: ShouldNotReachHere()
rschatz
parents: 35582
diff changeset
    49
        // 5 byte NOP:
3e83096ee8e5 8147475: compiler/jvmci/code/SimpleDebugInfoTest.java fails in Assembler::locate_operand: ShouldNotReachHere()
rschatz
parents: 35582
diff changeset
    50
        // NOP DWORD ptr [EAX + EAX*1 + 00H]
3e83096ee8e5 8147475: compiler/jvmci/code/SimpleDebugInfoTest.java fails in Assembler::locate_operand: ShouldNotReachHere()
rschatz
parents: 35582
diff changeset
    51
        code.emitByte(0x0F);
3e83096ee8e5 8147475: compiler/jvmci/code/SimpleDebugInfoTest.java fails in Assembler::locate_operand: ShouldNotReachHere()
rschatz
parents: 35582
diff changeset
    52
        code.emitByte(0x1F);
3e83096ee8e5 8147475: compiler/jvmci/code/SimpleDebugInfoTest.java fails in Assembler::locate_operand: ShouldNotReachHere()
rschatz
parents: 35582
diff changeset
    53
        code.emitByte(0x44);
3e83096ee8e5 8147475: compiler/jvmci/code/SimpleDebugInfoTest.java fails in Assembler::locate_operand: ShouldNotReachHere()
rschatz
parents: 35582
diff changeset
    54
        code.emitByte(0x00);
3e83096ee8e5 8147475: compiler/jvmci/code/SimpleDebugInfoTest.java fails in Assembler::locate_operand: ShouldNotReachHere()
rschatz
parents: 35582
diff changeset
    55
        code.emitByte(0x00);
3e83096ee8e5 8147475: compiler/jvmci/code/SimpleDebugInfoTest.java fails in Assembler::locate_operand: ShouldNotReachHere()
rschatz
parents: 35582
diff changeset
    56
    }
3e83096ee8e5 8147475: compiler/jvmci/code/SimpleDebugInfoTest.java fails in Assembler::locate_operand: ShouldNotReachHere()
rschatz
parents: 35582
diff changeset
    57
35582
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
    58
    @Override
35137
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
    59
    public void emitPrologue() {
35583
3e83096ee8e5 8147475: compiler/jvmci/code/SimpleDebugInfoTest.java fails in Assembler::locate_operand: ShouldNotReachHere()
rschatz
parents: 35582
diff changeset
    60
        // WARNING: Initial instruction MUST be 5 bytes or longer so that
3e83096ee8e5 8147475: compiler/jvmci/code/SimpleDebugInfoTest.java fails in Assembler::locate_operand: ShouldNotReachHere()
rschatz
parents: 35582
diff changeset
    61
        // NativeJump::patch_verified_entry will be able to patch out the entry
3e83096ee8e5 8147475: compiler/jvmci/code/SimpleDebugInfoTest.java fails in Assembler::locate_operand: ShouldNotReachHere()
rschatz
parents: 35582
diff changeset
    62
        // code safely.
3e83096ee8e5 8147475: compiler/jvmci/code/SimpleDebugInfoTest.java fails in Assembler::locate_operand: ShouldNotReachHere()
rschatz
parents: 35582
diff changeset
    63
        emitFatNop();
35582
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
    64
        code.emitByte(0x50 | AMD64.rbp.encoding);  // PUSH rbp
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
    65
        emitMove(true, AMD64.rbp, AMD64.rsp);      // MOV rbp, rsp
35823
59a847ec6ee3 8146608: [JVMCI] DebugInfo Tests on DeoptimizeALot runs fails in assert(_pc == *pc_addr || pc == *pc_addr) frame::patch_pc() /frame_x86.cpp:285
rschatz
parents: 35595
diff changeset
    66
        setDeoptRescueSlot(newStackSlot(LIRKind.value(AMD64Kind.QWORD)));
35137
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
    67
    }
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
    68
35582
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
    69
    @Override
35137
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
    70
    public void emitGrowStack(int size) {
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
    71
        // SUB rsp, size
35582
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
    72
        code.emitByte(0x48);
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
    73
        code.emitByte(0x81);
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
    74
        code.emitByte(0xEC);
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
    75
        code.emitInt(size);
35137
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
    76
    }
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
    77
35582
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
    78
    @Override
35137
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
    79
    public Register emitIntArg0() {
35595
4308ac6d1b16 8148101: [JVMCI] Make CallingConvention.Type extensible
never
parents: 35583
diff changeset
    80
        return codeCache.getRegisterConfig().getCallingConventionRegisters(HotSpotCallingConventionType.JavaCall, JavaKind.Int)[0];
35137
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
    81
    }
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
    82
35582
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
    83
    @Override
35137
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
    84
    public Register emitIntArg1() {
35595
4308ac6d1b16 8148101: [JVMCI] Make CallingConvention.Type extensible
never
parents: 35583
diff changeset
    85
        return codeCache.getRegisterConfig().getCallingConventionRegisters(HotSpotCallingConventionType.JavaCall, JavaKind.Int)[1];
35137
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
    86
    }
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
    87
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
    88
    private void emitREX(boolean w, int r, int x, int b) {
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
    89
        int wrxb = (w ? 0x08 : 0) | ((r >> 3) << 2) | ((x >> 3) << 1) | (b >> 3);
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
    90
        if (wrxb != 0) {
35582
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
    91
            code.emitByte(0x40 | wrxb);
35137
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
    92
        }
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
    93
    }
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
    94
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
    95
    private void emitModRMReg(boolean w, int opcode, int r, int m) {
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
    96
        emitREX(w, r, 0, m);
35582
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
    97
        code.emitByte((byte) opcode);
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
    98
        code.emitByte((byte) 0xC0 | ((r & 0x7) << 3) | (m & 0x7));
35137
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
    99
    }
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   100
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   101
    private void emitModRMMemory(boolean w, int opcode, int r, int b, int offset) {
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   102
        emitREX(w, r, 0, b);
35582
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
   103
        code.emitByte((byte) opcode);
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
   104
        code.emitByte((byte) 0x80 | ((r & 0x7) << 3) | (b & 0x7));
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
   105
        code.emitInt(offset);
35137
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   106
    }
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   107
35582
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
   108
    @Override
35137
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   109
    public Register emitLoadInt(int c) {
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   110
        Register ret = newRegister();
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   111
        emitREX(false, 0, 0, ret.encoding);
35582
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
   112
        code.emitByte(0xB8 | (ret.encoding & 0x7)); // MOV r32, imm32
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
   113
        code.emitInt(c);
35137
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   114
        return ret;
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   115
    }
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   116
35582
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
   117
    @Override
35137
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   118
    public Register emitLoadLong(long c) {
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   119
        Register ret = newRegister();
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   120
        emitREX(true, 0, 0, ret.encoding);
35582
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
   121
        code.emitByte(0xB8 | (ret.encoding & 0x7)); // MOV r64, imm64
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
   122
        code.emitLong(c);
35137
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   123
        return ret;
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   124
    }
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   125
35582
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
   126
    @Override
35137
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   127
    public Register emitLoadFloat(float c) {
35582
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
   128
        DataSectionReference ref = new DataSectionReference();
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
   129
        ref.setOffset(data.position());
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
   130
        data.emitFloat(c);
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
   131
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
   132
        recordDataPatchInCode(ref);
35137
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   133
        Register ret = AMD64.xmm0;
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   134
        emitREX(false, ret.encoding, 0, 0);
35582
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
   135
        code.emitByte(0xF3);
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
   136
        code.emitByte(0x0F);
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
   137
        code.emitByte(0x10);                               // MOVSS xmm1, xmm2/m32
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
   138
        code.emitByte(0x05 | ((ret.encoding & 0x7) << 3)); // xmm, [rip+offset]
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
   139
        code.emitInt(0xDEADDEAD);
35137
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   140
        return ret;
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   141
    }
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   142
35582
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
   143
    @Override
35137
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   144
    public Register emitLoadPointer(HotSpotConstant c) {
35582
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
   145
        recordDataPatchInCode(new ConstantReference((VMConstant) c));
35137
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   146
        if (c.isCompressed()) {
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   147
            Register ret = newRegister();
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   148
            emitREX(false, 0, 0, ret.encoding);
35582
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
   149
            code.emitByte(0xB8 | (ret.encoding & 0x7)); // MOV r32, imm32
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
   150
            code.emitInt(0xDEADDEAD);
35137
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   151
            return ret;
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   152
        } else {
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   153
            return emitLoadLong(0xDEADDEADDEADDEADl);
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   154
        }
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   155
    }
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   156
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   157
    private Register emitLoadPointer(DataSectionReference ref, boolean narrow) {
35582
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
   158
        recordDataPatchInCode(ref);
35137
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   159
        Register ret = newRegister();
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   160
        emitREX(!narrow, ret.encoding, 0, 0);
35582
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
   161
        code.emitByte(0x8B);                               // MOV r64,r/m64
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
   162
        code.emitByte(0x05 | ((ret.encoding & 0x7) << 3)); // r64, [rip+offset]
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
   163
        code.emitInt(0xDEADDEAD);
35137
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   164
        return ret;
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   165
    }
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   166
35582
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
   167
    @Override
35137
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   168
    public Register emitLoadPointer(DataSectionReference ref) {
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   169
        return emitLoadPointer(ref, false);
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   170
    }
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   171
35582
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
   172
    @Override
35137
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   173
    public Register emitLoadNarrowPointer(DataSectionReference ref) {
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   174
        return emitLoadPointer(ref, true);
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   175
    }
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   176
35582
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
   177
    @Override
35137
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   178
    public Register emitLoadPointer(Register b, int offset) {
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   179
        Register ret = newRegister();
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   180
        emitModRMMemory(true, 0x8B, ret.encoding, b.encoding, offset); // MOV r64,r/m64
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   181
        return ret;
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   182
    }
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   183
35582
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
   184
    @Override
35137
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   185
    public StackSlot emitIntToStack(Register a) {
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   186
        StackSlot ret = newStackSlot(LIRKind.value(AMD64Kind.DWORD));
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   187
        emitModRMMemory(false, 0x89, a.encoding, AMD64.rbp.encoding, ret.getRawOffset() + 16); // MOV r/m32,r32
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   188
        return ret;
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   189
    }
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   190
35582
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
   191
    @Override
35137
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   192
    public StackSlot emitLongToStack(Register a) {
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   193
        StackSlot ret = newStackSlot(LIRKind.value(AMD64Kind.QWORD));
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   194
        emitModRMMemory(true, 0x89, a.encoding, AMD64.rbp.encoding, ret.getRawOffset() + 16); // MOV r/m64,r64
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   195
        return ret;
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   196
    }
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   197
35582
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
   198
    @Override
35137
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   199
    public StackSlot emitFloatToStack(Register a) {
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   200
        StackSlot ret = newStackSlot(LIRKind.value(AMD64Kind.SINGLE));
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   201
        emitREX(false, a.encoding, 0, 0);
35582
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
   202
        code.emitByte(0xF3);
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
   203
        code.emitByte(0x0F);
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
   204
        code.emitByte(0x11);                               // MOVSS xmm2/m32, xmm1
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
   205
        code.emitByte(0x85 | ((a.encoding & 0x7) << 3));   // [rbp+offset]
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
   206
        code.emitInt(ret.getRawOffset() + 16);
35137
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   207
        return ret;
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   208
    }
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   209
35582
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
   210
    @Override
35137
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   211
    public StackSlot emitPointerToStack(Register a) {
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   212
        StackSlot ret = newStackSlot(LIRKind.reference(AMD64Kind.QWORD));
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   213
        emitModRMMemory(true, 0x89, a.encoding, AMD64.rbp.encoding, ret.getRawOffset() + 16); // MOV r/m64,r64
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   214
        return ret;
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   215
    }
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   216
35582
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
   217
    @Override
35137
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   218
    public StackSlot emitNarrowPointerToStack(Register a) {
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   219
        StackSlot ret = newStackSlot(LIRKind.reference(AMD64Kind.DWORD));
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   220
        emitModRMMemory(false, 0x89, a.encoding, AMD64.rbp.encoding, ret.getRawOffset() + 16); // MOV r/m32,r32
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   221
        return ret;
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   222
    }
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   223
35582
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
   224
    @Override
35137
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   225
    public Register emitUncompressPointer(Register compressed, long base, int shift) {
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   226
        if (shift > 0) {
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   227
            emitModRMReg(true, 0xC1, 4, compressed.encoding);
35582
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
   228
            code.emitByte(shift);
35137
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   229
        }
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   230
        if (base == 0) {
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   231
            return compressed;
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   232
        } else {
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   233
            Register tmp = emitLoadLong(base);
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   234
            emitModRMReg(true, 0x03, tmp.encoding, compressed.encoding);
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   235
            return tmp;
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   236
        }
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   237
    }
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   238
35582
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
   239
    @Override
35137
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   240
    public Register emitIntAdd(Register a, Register b) {
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   241
        emitModRMReg(false, 0x03, a.encoding, b.encoding);
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   242
        return a;
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   243
    }
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   244
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   245
    private void emitMove(boolean w, Register to, Register from) {
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   246
        if (to != from) {
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   247
            emitModRMReg(w, 0x8B, to.encoding, from.encoding);
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   248
        }
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   249
    }
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   250
35582
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
   251
    @Override
35137
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   252
    public void emitIntRet(Register a) {
35582
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
   253
        emitMove(false, AMD64.rax, a);             // MOV eax, ...
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
   254
        emitMove(true, AMD64.rsp, AMD64.rbp);      // MOV rsp, rbp
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
   255
        code.emitByte(0x58 | AMD64.rbp.encoding);  // POP rbp
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
   256
        code.emitByte(0xC3);                       // RET
35137
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   257
    }
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   258
35582
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
   259
    @Override
35137
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   260
    public void emitPointerRet(Register a) {
35582
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
   261
        emitMove(true, AMD64.rax, a);              // MOV rax, ...
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
   262
        emitMove(true, AMD64.rsp, AMD64.rbp);      // MOV rsp, rbp
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
   263
        code.emitByte(0x58 | AMD64.rbp.encoding);  // POP rbp
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
   264
        code.emitByte(0xC3);                       // RET
35137
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   265
    }
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   266
35582
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
   267
    @Override
35137
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   268
    public void emitTrap(DebugInfo info) {
35582
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
   269
        recordImplicitException(info);
35137
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   270
        // MOV rax, [0]
35582
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
   271
        code.emitByte(0x8B);
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
   272
        code.emitByte(0x04);
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
   273
        code.emitByte(0x25);
c32a0cc19877 8147599: [JVMCI] simplify code installation interface
rschatz
parents: 35144
diff changeset
   274
        code.emitInt(0);
35137
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   275
    }
c8f8f6de68a7 8144704: [JVMCI] add tests for simple code installation
rschatz
parents:
diff changeset
   276
}