Mercurial > hg > truffle
view graal/com.oracle.graal.snippets.test/src/com/oracle/graal/snippets/WordTest.java @ 7530:5e3d1a68664e
applied mx eclipseformat to all Java files
author | Doug Simon <doug.simon@oracle.com> |
---|---|
date | Wed, 23 Jan 2013 16:34:57 +0100 |
parents | 2912b72d840a |
children | 72971ec0d7ae |
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.snippets; import java.lang.reflect.*; import org.junit.*; import com.oracle.graal.api.code.*; import com.oracle.graal.api.meta.*; import com.oracle.graal.api.runtime.*; import com.oracle.graal.compiler.*; import com.oracle.graal.compiler.test.*; import com.oracle.graal.nodes.*; import com.oracle.graal.snippets.Snippet.SnippetInliningPolicy; import com.oracle.graal.word.*; /** * Tests for the {@link Word} type. */ public class WordTest extends GraalCompilerTest implements SnippetsInterface { private final SnippetInstaller installer; public WordTest() { TargetDescription target = Graal.getRequiredCapability(GraalCompiler.class).target; installer = new SnippetInstaller(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(), false); } @Test 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); } } @Test 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); } } } @Test 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(); } }