blob: eb7c8d6d2d1228fcd58d8779432c3ab02f495ff8 [file] [log] [blame]
// Copyright (c) 2016, the Dart project authors. Please see the AUTHORS file
// for details. All rights reserved. Use of this source code is governed by a
// BSD-style license that can be found in the LICENSE file.
//
// VMOptions=--enable-testing-pragmas --no-background-compilation --optimization-counter-threshold=10 -Denable_inlining=true --compilation-counter-threshold=1
// VMOptions=--enable-testing-pragmas --no-background-compilation --optimization-counter-threshold=10 --compilation-counter-threshold=1
// VMOptions=--enable-testing-pragmas --no-background-compilation --optimization-counter-threshold=-1 --compilation-counter-threshold=1
// @dart = 2.9
// Test that 'PolymorphicInstanceCall's against "this" go through the unchecked
// entrypoint. The use of optional arguments here encourages prologue sharing
// between the entrypoints.
import "../common.dart";
import "package:expect/expect.dart";
abstract class C<T> {
@NeverInline
void samir1(T x) {
samir2(x, y: "hi");
}
void samir2(T x, {String y});
}
class D<T> extends C<T> {
@NeverInline
@pragma("vm:testing.unsafe.trace-entrypoints-fn", validate)
@pragma("vm:entry-point")
void samir2(T x, {String y}) {
Expect.notEquals(x, -1);
Expect.equals(y, "hi");
}
}
class E<T> extends C<T> {
@NeverInline
@pragma("vm:testing.unsafe.trace-entrypoints-fn", validate)
@pragma("vm:entry-point")
void samir2(T x, {String y}) {
Expect.notEquals(x, -1);
Expect.equals(y, "hi");
}
}
int j = 0;
C getC() {
if (j % 2 == 0) {
++j;
return new D<int>();
} else {
++j;
return new E<int>();
}
}
main(List<String> args) {
const int iterations = benchmarkMode ? 100000000 : 100;
for (int i = 0; i < iterations; ++i) {
getC().samir1(i);
}
entryPoint.expectUnchecked(iterations);
}