Search in sources :

Example 16 with RegisterConfig

use of jdk.vm.ci.code.RegisterConfig in project graal by oracle.

the class BitOpsTest method lzcntqTest.

@Test
public void lzcntqTest() {
    if (lzcntSupported) {
        CodeGenTest test = new CodeGenTest() {

            @Override
            public byte[] generateCode(CompilationResult compResult, TargetDescription target, RegisterConfig registerConfig, CallingConvention cc) {
                AMD64Assembler asm = new AMD64Assembler(target);
                Register ret = registerConfig.getReturnRegister(JavaKind.Int);
                Register arg = asRegister(cc.getArgument(0));
                LZCNT.emit(asm, QWORD, ret, arg);
                asm.ret(0);
                return asm.close(true);
            }
        };
        assertReturn("longStub", test, 63, 1L);
    }
}
Also used : CallingConvention(jdk.vm.ci.code.CallingConvention) RegisterConfig(jdk.vm.ci.code.RegisterConfig) Register(jdk.vm.ci.code.Register) ValueUtil.asRegister(jdk.vm.ci.code.ValueUtil.asRegister) AMD64Assembler(org.graalvm.compiler.asm.amd64.AMD64Assembler) TargetDescription(jdk.vm.ci.code.TargetDescription) CompilationResult(org.graalvm.compiler.code.CompilationResult) Test(org.junit.Test) AssemblerTest(org.graalvm.compiler.asm.test.AssemblerTest)

Example 17 with RegisterConfig

use of jdk.vm.ci.code.RegisterConfig in project graal by oracle.

the class BitOpsTest method tzcntlTest.

@Test
public void tzcntlTest() {
    if (tzcntSupported) {
        CodeGenTest test = new CodeGenTest() {

            @Override
            public byte[] generateCode(CompilationResult compResult, TargetDescription target, RegisterConfig registerConfig, CallingConvention cc) {
                AMD64Assembler asm = new AMD64Assembler(target);
                Register ret = registerConfig.getReturnRegister(JavaKind.Int);
                Register arg = asRegister(cc.getArgument(0));
                TZCNT.emit(asm, DWORD, ret, arg);
                asm.ret(0);
                return asm.close(true);
            }
        };
        assertReturn("intStub", test, 31, 0x8000_0000);
    }
}
Also used : CallingConvention(jdk.vm.ci.code.CallingConvention) RegisterConfig(jdk.vm.ci.code.RegisterConfig) Register(jdk.vm.ci.code.Register) ValueUtil.asRegister(jdk.vm.ci.code.ValueUtil.asRegister) AMD64Assembler(org.graalvm.compiler.asm.amd64.AMD64Assembler) TargetDescription(jdk.vm.ci.code.TargetDescription) CompilationResult(org.graalvm.compiler.code.CompilationResult) Test(org.junit.Test) AssemblerTest(org.graalvm.compiler.asm.test.AssemblerTest)

Example 18 with RegisterConfig

use of jdk.vm.ci.code.RegisterConfig in project graal by oracle.

the class SimpleAssemblerTest method intTest.

@Test
public void intTest() {
    CodeGenTest test = new CodeGenTest() {

        @Override
        public byte[] generateCode(CompilationResult compResult, TargetDescription target, RegisterConfig registerConfig, CallingConvention cc) {
            AMD64Assembler asm = new AMD64Assembler(target);
            Register ret = registerConfig.getReturnRegister(JavaKind.Int);
            asm.movl(ret, 8472);
            asm.ret(0);
            return asm.close(true);
        }
    };
    assertReturn("intStub", test, 8472);
}
Also used : CallingConvention(jdk.vm.ci.code.CallingConvention) RegisterConfig(jdk.vm.ci.code.RegisterConfig) Register(jdk.vm.ci.code.Register) AMD64Assembler(org.graalvm.compiler.asm.amd64.AMD64Assembler) TargetDescription(jdk.vm.ci.code.TargetDescription) CompilationResult(org.graalvm.compiler.code.CompilationResult) Test(org.junit.Test) AssemblerTest(org.graalvm.compiler.asm.test.AssemblerTest)

Example 19 with RegisterConfig

use of jdk.vm.ci.code.RegisterConfig in project graal by oracle.

the class HotSpotForeignCallLinkageImpl method createCallingConvention.

/**
 * Gets a calling convention for a given descriptor and call type.
 */
public static CallingConvention createCallingConvention(MetaAccessProvider metaAccess, CodeCacheProvider codeCache, WordTypes wordTypes, ValueKindFactory<?> valueKindFactory, ForeignCallDescriptor descriptor, Type ccType) {
    assert ccType != null;
    Class<?>[] argumentTypes = descriptor.getArgumentTypes();
    JavaType[] parameterTypes = new JavaType[argumentTypes.length];
    for (int i = 0; i < parameterTypes.length; ++i) {
        parameterTypes[i] = asJavaType(argumentTypes[i], metaAccess, wordTypes);
    }
    JavaType returnType = asJavaType(descriptor.getResultType(), metaAccess, wordTypes);
    RegisterConfig regConfig = codeCache.getRegisterConfig();
    return regConfig.getCallingConvention(ccType, returnType, parameterTypes, valueKindFactory);
}
Also used : RegisterConfig(jdk.vm.ci.code.RegisterConfig) ResolvedJavaType(jdk.vm.ci.meta.ResolvedJavaType) JavaType(jdk.vm.ci.meta.JavaType)

Aggregations

RegisterConfig (jdk.vm.ci.code.RegisterConfig)19 Register (jdk.vm.ci.code.Register)14 CallingConvention (jdk.vm.ci.code.CallingConvention)13 TargetDescription (jdk.vm.ci.code.TargetDescription)12 CompilationResult (org.graalvm.compiler.code.CompilationResult)12 AssemblerTest (org.graalvm.compiler.asm.test.AssemblerTest)11 Test (org.junit.Test)11 ValueUtil.asRegister (jdk.vm.ci.code.ValueUtil.asRegister)9 AMD64Assembler (org.graalvm.compiler.asm.amd64.AMD64Assembler)9 AMD64Address (org.graalvm.compiler.asm.amd64.AMD64Address)5 Field (java.lang.reflect.Field)4 FrameMap (org.graalvm.compiler.lir.framemap.FrameMap)4 Label (org.graalvm.compiler.asm.Label)3 AMD64MacroAssembler (org.graalvm.compiler.asm.amd64.AMD64MacroAssembler)3 DataSectionReference (jdk.vm.ci.code.site.DataSectionReference)2 Data (org.graalvm.compiler.code.DataSection.Data)2 RawData (org.graalvm.compiler.code.DataSection.RawData)2 SerializableData (org.graalvm.compiler.code.DataSection.SerializableData)2 SubstrateAMD64RegisterConfig (com.oracle.svm.core.graal.code.amd64.SubstrateAMD64RegisterConfig)1 ConfigKind (com.oracle.svm.core.graal.code.amd64.SubstrateAMD64RegisterConfig.ConfigKind)1