From 7415b64ed669dd6ae1c1eea432e3660ab1089bfe Mon Sep 17 00:00:00 2001 From: Attila Szegedi Date: Mon, 8 Feb 2016 12:59:08 +0100 Subject: [PATCH] 8149186: Don't use indy for optimistic arithmetic Reviewed-by: mhaupt, sundar --- .../internal/codegen/types/BooleanType.java | 9 ++--- .../internal/codegen/types/IntType.java | 20 ++++++---- .../internal/codegen/types/LongType.java | 11 +----- .../nashorn/internal/codegen/types/Type.java | 13 +------ .../internal/runtime/linker/Bootstrap.java | 39 +------------------ 5 files changed, 20 insertions(+), 72 deletions(-) diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/codegen/types/BooleanType.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/codegen/types/BooleanType.java index 9cc239a8436..10bbfddaa2a 100644 --- a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/codegen/types/BooleanType.java +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/codegen/types/BooleanType.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2010, 2013, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2010, 2016, 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 @@ -134,11 +134,8 @@ public final class BooleanType extends Type { @Override public Type add(final MethodVisitor method, final int programPoint) { // Adding booleans in JavaScript is perfectly valid, they add as if false=0 and true=1 - if(programPoint == INVALID_PROGRAM_POINT) { - method.visitInsn(IADD); - } else { - method.visitInvokeDynamicInsn("iadd", "(II)I", MATHBOOTSTRAP, programPoint); - } + assert programPoint == INVALID_PROGRAM_POINT; + method.visitInsn(IADD); return INT; } } diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/codegen/types/IntType.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/codegen/types/IntType.java index 76c86046c01..ffad71e4e5f 100644 --- a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/codegen/types/IntType.java +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/codegen/types/IntType.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2010, 2013, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2010, 2016, 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 @@ -155,7 +155,8 @@ class IntType extends BitwiseType { if(programPoint == INVALID_PROGRAM_POINT) { method.visitInsn(IADD); } else { - method.visitInvokeDynamicInsn("iadd", "(II)I", MATHBOOTSTRAP, programPoint); + ldc(method, programPoint); + JSType.ADD_EXACT.invoke(method); } return INT; } @@ -214,7 +215,8 @@ class IntType extends BitwiseType { if(programPoint == INVALID_PROGRAM_POINT) { method.visitInsn(ISUB); } else { - method.visitInvokeDynamicInsn("isub", "(II)I", MATHBOOTSTRAP, programPoint); + ldc(method, programPoint); + JSType.SUB_EXACT.invoke(method); } return INT; } @@ -224,7 +226,8 @@ class IntType extends BitwiseType { if(programPoint == INVALID_PROGRAM_POINT) { method.visitInsn(IMUL); } else { - method.visitInvokeDynamicInsn("imul", "(II)I", MATHBOOTSTRAP, programPoint); + ldc(method, programPoint); + JSType.MUL_EXACT.invoke(method); } return INT; } @@ -234,7 +237,8 @@ class IntType extends BitwiseType { if (programPoint == INVALID_PROGRAM_POINT) { JSType.DIV_ZERO.invoke(method); } else { - method.visitInvokeDynamicInsn("idiv", "(II)I", MATHBOOTSTRAP, programPoint); + ldc(method, programPoint); + JSType.DIV_EXACT.invoke(method); } return INT; } @@ -244,7 +248,8 @@ class IntType extends BitwiseType { if (programPoint == INVALID_PROGRAM_POINT) { JSType.REM_ZERO.invoke(method); } else { - method.visitInvokeDynamicInsn("irem", "(II)I", MATHBOOTSTRAP, programPoint); + ldc(method, programPoint); + JSType.REM_EXACT.invoke(method); } return INT; } @@ -254,7 +259,8 @@ class IntType extends BitwiseType { if(programPoint == INVALID_PROGRAM_POINT) { method.visitInsn(INEG); } else { - method.visitInvokeDynamicInsn("ineg", "(I)I", MATHBOOTSTRAP, programPoint); + ldc(method, programPoint); + JSType.NEGATE_EXACT.invoke(method); } return INT; } diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/codegen/types/LongType.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/codegen/types/LongType.java index aa4b5398a09..7a19d3bbec6 100644 --- a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/codegen/types/LongType.java +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/codegen/types/LongType.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2010, 2013, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2010, 2016, 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 @@ -27,7 +27,6 @@ package jdk.nashorn.internal.codegen.types; import static jdk.internal.org.objectweb.asm.Opcodes.L2D; import static jdk.internal.org.objectweb.asm.Opcodes.L2I; -import static jdk.internal.org.objectweb.asm.Opcodes.LADD; import static jdk.internal.org.objectweb.asm.Opcodes.LCONST_0; import static jdk.internal.org.objectweb.asm.Opcodes.LCONST_1; import static jdk.internal.org.objectweb.asm.Opcodes.LLOAD; @@ -35,7 +34,6 @@ import static jdk.internal.org.objectweb.asm.Opcodes.LRETURN; import static jdk.internal.org.objectweb.asm.Opcodes.LSTORE; import static jdk.nashorn.internal.codegen.CompilerConstants.staticCallNoLookup; import static jdk.nashorn.internal.runtime.JSType.UNDEFINED_LONG; -import static jdk.nashorn.internal.runtime.UnwarrantedOptimismException.INVALID_PROGRAM_POINT; import jdk.internal.org.objectweb.asm.MethodVisitor; import jdk.nashorn.internal.codegen.CompilerConstants; @@ -125,12 +123,7 @@ class LongType extends Type { @Override public Type add(final MethodVisitor method, final int programPoint) { - if(programPoint == INVALID_PROGRAM_POINT) { - method.visitInsn(LADD); - } else { - method.visitInvokeDynamicInsn("ladd", "(JJ)J", MATHBOOTSTRAP, programPoint); - } - return LONG; + throw new UnsupportedOperationException("add"); } @Override diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/codegen/types/Type.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/codegen/types/Type.java index 5b23c1cb8df..fe8ab811f2f 100644 --- a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/codegen/types/Type.java +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/codegen/types/Type.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2010, 2013, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2010, 2016, 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 @@ -33,7 +33,6 @@ import static jdk.internal.org.objectweb.asm.Opcodes.DUP2_X1; import static jdk.internal.org.objectweb.asm.Opcodes.DUP2_X2; import static jdk.internal.org.objectweb.asm.Opcodes.DUP_X1; import static jdk.internal.org.objectweb.asm.Opcodes.DUP_X2; -import static jdk.internal.org.objectweb.asm.Opcodes.H_INVOKESTATIC; import static jdk.internal.org.objectweb.asm.Opcodes.IALOAD; import static jdk.internal.org.objectweb.asm.Opcodes.IASTORE; import static jdk.internal.org.objectweb.asm.Opcodes.INVOKESTATIC; @@ -46,28 +45,22 @@ import static jdk.internal.org.objectweb.asm.Opcodes.SWAP; import static jdk.internal.org.objectweb.asm.Opcodes.T_DOUBLE; import static jdk.internal.org.objectweb.asm.Opcodes.T_INT; import static jdk.internal.org.objectweb.asm.Opcodes.T_LONG; -import static jdk.nashorn.internal.codegen.CompilerConstants.staticCallNoLookup; import java.io.DataInput; import java.io.DataOutput; import java.io.IOException; import java.io.Serializable; -import java.lang.invoke.CallSite; -import java.lang.invoke.MethodHandles; -import java.lang.invoke.MethodType; import java.util.Collections; import java.util.Map; import java.util.TreeMap; import java.util.WeakHashMap; import java.util.concurrent.ConcurrentHashMap; import java.util.concurrent.ConcurrentMap; -import jdk.internal.org.objectweb.asm.Handle; import jdk.internal.org.objectweb.asm.MethodVisitor; import jdk.nashorn.internal.codegen.CompilerConstants.Call; import jdk.nashorn.internal.runtime.Context; import jdk.nashorn.internal.runtime.ScriptObject; import jdk.nashorn.internal.runtime.Undefined; -import jdk.nashorn.internal.runtime.linker.Bootstrap; /** * This is the representation of a JavaScript type, disassociated from java @@ -124,10 +117,6 @@ public abstract class Type implements Comparable, BytecodeOps, Serializabl /** Set way below Integer.MAX_VALUE to prevent overflow when adding weights. Objects are still heaviest. */ protected static final int MAX_WEIGHT = 20; - static final Call BOOTSTRAP = staticCallNoLookup(Bootstrap.class, "mathBootstrap", CallSite.class, MethodHandles.Lookup.class, String.class, MethodType.class, int.class); - - static final Handle MATHBOOTSTRAP = new Handle(H_INVOKESTATIC, BOOTSTRAP.className(), "mathBootstrap", BOOTSTRAP.descriptor()); - /** * Constructor * diff --git a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/runtime/linker/Bootstrap.java b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/runtime/linker/Bootstrap.java index 2c3801a5fef..387ec8c96e1 100644 --- a/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/runtime/linker/Bootstrap.java +++ b/nashorn/src/jdk.scripting.nashorn/share/classes/jdk/nashorn/internal/runtime/linker/Bootstrap.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2010, 2013, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2010, 2016, 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 @@ -29,7 +29,6 @@ import static jdk.nashorn.internal.codegen.CompilerConstants.staticCallNoLookup; import static jdk.nashorn.internal.runtime.ECMAErrors.typeError; import java.lang.invoke.CallSite; -import java.lang.invoke.ConstantCallSite; import java.lang.invoke.MethodHandle; import java.lang.invoke.MethodHandles; import java.lang.invoke.MethodHandles.Lookup; @@ -203,42 +202,6 @@ public final class Bootstrap { return Context.getDynamicLinker(lookup.lookupClass()).link(LinkerCallSite.newLinkerCallSite(lookup, opDesc, type, flags)); } - /** - * Boostrapper for math calls that may overflow - * @param lookup lookup - * @param name name of operation - * @param type method type - * @param programPoint program point to bind to callsite - * - * @return callsite for a math intrinsic node - */ - public static CallSite mathBootstrap(final Lookup lookup, final String name, final MethodType type, final int programPoint) { - final MethodHandle mh; - switch (name) { - case "iadd": - mh = JSType.ADD_EXACT.methodHandle(); - break; - case "isub": - mh = JSType.SUB_EXACT.methodHandle(); - break; - case "imul": - mh = JSType.MUL_EXACT.methodHandle(); - break; - case "idiv": - mh = JSType.DIV_EXACT.methodHandle(); - break; - case "irem": - mh = JSType.REM_EXACT.methodHandle(); - break; - case "ineg": - mh = JSType.NEGATE_EXACT.methodHandle(); - break; - default: - throw new AssertionError("unsupported math intrinsic"); - } - return new ConstantCallSite(MH.insertArguments(mh, mh.type().parameterCount() - 1, programPoint)); - } - /** * Returns a dynamic invoker for a specified dynamic operation using the * public lookup. You can use this method to create a method handle that