# HG changeset patch # User Christian Wimmer # Date 1396478459 25200 # Node ID 5a87cbdd8a09e6d6a72377f8acc361acedd7dff3 # Parent 6decd59291a85fb40643044f55800c269588e206# Parent 6b29befc7f38ef0539051d1e3cda87e98a47c029 Merge diff -r 6decd59291a8 -r 5a87cbdd8a09 graal/com.oracle.graal.replacements/src/com/oracle/graal/replacements/NodeIntrinsificationPhase.java --- a/graal/com.oracle.graal.replacements/src/com/oracle/graal/replacements/NodeIntrinsificationPhase.java Wed Apr 02 11:54:49 2014 -0700 +++ b/graal/com.oracle.graal.replacements/src/com/oracle/graal/replacements/NodeIntrinsificationPhase.java Wed Apr 02 15:40:59 2014 -0700 @@ -70,9 +70,10 @@ protected boolean tryIntrinsify(MethodCallTargetNode methodCallTargetNode, List cleanUpReturnList) { ResolvedJavaMethod target = methodCallTargetNode.targetMethod(); - NodeIntrinsic intrinsic = target.getAnnotation(Node.NodeIntrinsic.class); ResolvedJavaType declaringClass = target.getDeclaringClass(); StructuredGraph graph = methodCallTargetNode.graph(); + + NodeIntrinsic intrinsic = getIntrinsic(target); if (intrinsic != null) { assert target.getAnnotation(Fold.class) == null; assert Modifier.isStatic(target.getModifiers()) : "node intrinsic must be static: " + target; @@ -129,6 +130,13 @@ } /** + * Permits a subclass to override the default definition of "intrinsic". + */ + protected NodeIntrinsic getIntrinsic(ResolvedJavaMethod method) { + return method.getAnnotation(Node.NodeIntrinsic.class); + } + + /** * Permits a subclass to override the default definition of "foldable". */ protected boolean isFoldable(ResolvedJavaMethod method) {