Mercurial > hg > graal-jvmci-8
view graal/com.oracle.graal.replacements.test/src/com/oracle/graal/replacements/WordTest.java @ 8416:102b5249e97e
rename projects: *snippets* -> *replacements* (GRAAL-178)
author | Doug Simon <doug.simon@oracle.com> |
---|---|
date | Wed, 20 Mar 2013 22:30:33 +0100 |
parents | graal/com.oracle.graal.snippets.test/src/com/oracle/graal/replacements/WordTest.java@2361bf148c06 |
children | 77de2f3df379 |
line wrap: on
line source
/* * Copyright (c) 2011, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License version 2 only, as * published by the Free Software Foundation. * * This code is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License * version 2 for more details (a copy is included in the LICENSE file that * accompanied this code). * * You should have received a copy of the GNU General Public License version * 2 along with this work; if not, write to the Free Software Foundation, * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. * * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA * or visit www.oracle.com if you need additional information or have any * questions. */ package com.oracle.graal.replacements; import java.lang.reflect.*; import com.oracle.graal.api.code.*; import com.oracle.graal.api.meta.*; import com.oracle.graal.api.runtime.*; import com.oracle.graal.compiler.test.*; import com.oracle.graal.test.*; import com.oracle.graal.nodes.*; import com.oracle.graal.replacements.Snippet.*; import com.oracle.graal.word.*; /** * Tests for the {@link Word} type. */ public class WordTest extends GraalCompilerTest implements Snippets { private final ReplacementsInstaller installer; public WordTest() { TargetDescription target = Graal.getRequiredCapability(CodeCacheProvider.class).getTarget(); installer = new ReplacementsInstaller(runtime, new Assumptions(false), target); } private static final ThreadLocal<SnippetInliningPolicy> inliningPolicy = new ThreadLocal<>(); @Override protected StructuredGraph parse(Method m) { ResolvedJavaMethod resolvedMethod = runtime.lookupJavaMethod(m); return installer.makeGraph(resolvedMethod, inliningPolicy.get()); } @LongTest public void construction() { long[] words = new long[]{Long.MIN_VALUE, Long.MIN_VALUE + 1, -1L, 0L, 1L, Long.MAX_VALUE - 1, Long.MAX_VALUE, Integer.MAX_VALUE - 1L, Integer.MAX_VALUE, Integer.MAX_VALUE + 1L, Integer.MIN_VALUE - 1L, Integer.MIN_VALUE, Integer.MIN_VALUE + 1L}; for (long word : words) { test("unsigned_long", word); test("unsigned_int", (int) word); test("signed_long", word); test("signed_int", (int) word); } } @LongTest public void test_arithmetic() { long[] words = new long[]{Long.MIN_VALUE, Long.MIN_VALUE + 1, -1L, 0L, 1L, Long.MAX_VALUE - 1, Long.MAX_VALUE, Integer.MAX_VALUE - 1L, Integer.MAX_VALUE, Integer.MAX_VALUE + 1L, Integer.MIN_VALUE - 1L, Integer.MIN_VALUE, Integer.MIN_VALUE + 1L}; for (long word : words) { test("unsigned_not", word); test("signed_not", word); for (long addend : words) { test("unsigned_plus_int", word, (int) addend); test("unsigned_minus_int", word, (int) addend); test("unsigned_plus_int", word, -((int) addend)); test("unsigned_minus_int", word, -((int) addend)); test("unsigned_plus_long", word, addend); test("unsigned_minus_long", word, addend); test("unsigned_plus_long", word, -addend); test("unsigned_minus_long", word, -addend); test("signed_plus_int", word, (int) addend); test("signed_minus_int", word, (int) addend); test("signed_plus_int", word, -((int) addend)); test("signed_minus_int", word, -((int) addend)); test("signed_plus_long", word, addend); test("signed_minus_long", word, addend); test("signed_plus_long", word, -addend); test("signed_minus_long", word, -addend); test("and_int", word, (int) addend); test("or_int", word, (int) addend); test("and_int", word, -((int) addend)); test("or_int", word, -((int) addend)); test("and_long", word, addend); test("or_long", word, addend); test("and_long", word, -addend); test("or_long", word, -addend); } } } @LongTest public void test_compare() { long[] words = new long[]{Long.MIN_VALUE, Long.MIN_VALUE + 1, -1L, 0L, 1L, Long.MAX_VALUE - 1, Long.MAX_VALUE}; for (long word1 : words) { for (long word2 : words) { for (String method : new String[]{"aboveOrEqual", "above", "belowOrEqual", "below"}) { test(method, word1, word2); test(method, word2, word1); } } } } @Snippet public static long unsigned_long(long word) { return Word.unsigned(word).rawValue(); } @Snippet public static long unsigned_int(int word) { return Word.unsigned(word).rawValue(); } @Snippet public static long signed_long(long word) { return Word.signed(word).rawValue(); } @Snippet public static long signed_int(int word) { return Word.signed(word).rawValue(); } @Snippet public static long unsigned_plus_int(long word, int addend) { return Word.unsigned(word).add(addend).rawValue(); } @Snippet public static long unsigned_minus_int(long word, int addend) { return Word.unsigned(word).subtract(addend).rawValue(); } @Snippet public static long unsigned_plus_long(long word, long addend) { return Word.unsigned(word).add(Word.unsigned(addend)).rawValue(); } @Snippet public static long unsigned_minus_long(long word, long addend) { return Word.unsigned(word).subtract(Word.unsigned(addend)).rawValue(); } @Snippet public static long signed_plus_int(long word, int addend) { return Word.signed(word).add(addend).rawValue(); } @Snippet public static long signed_minus_int(long word, int addend) { return Word.signed(word).subtract(addend).rawValue(); } @Snippet public static long signed_plus_long(long word, long addend) { return Word.signed(word).add(Word.signed(addend)).rawValue(); } @Snippet public static long signed_minus_long(long word, long addend) { return Word.signed(word).subtract(Word.signed(addend)).rawValue(); } @Snippet public static long signed_not(long word) { return Word.signed(word).not().rawValue(); } @Snippet public static long unsigned_not(long word) { return Word.unsigned(word).not().rawValue(); } @Snippet public static boolean aboveOrEqual(long word1, long word2) { return Word.unsigned(word1).aboveOrEqual(Word.unsigned(word2)); } @Snippet public static boolean above(long word1, long word2) { return Word.unsigned(word1).aboveThan(Word.unsigned(word2)); } @Snippet public static boolean belowOrEqual(long word1, long word2) { return Word.unsigned(word1).belowOrEqual(Word.unsigned(word2)); } @Snippet public static boolean below(long word1, long word2) { return Word.unsigned(word1).belowThan(Word.unsigned(word2)); } @Snippet public static long and_int(long word, int addend) { return Word.unsigned(word).and(addend).rawValue(); } @Snippet public static long or_int(long word, int addend) { return Word.unsigned(word).or(addend).rawValue(); } @Snippet public static long and_long(long word, long addend) { return Word.unsigned(word).and(Word.unsigned(addend)).rawValue(); } @Snippet public static long or_long(long word, long addend) { return Word.unsigned(word).or(Word.unsigned(addend)).rawValue(); } }