mirror of
https://github.com/dart-lang/sdk
synced 2024-11-02 08:20:31 +00:00
07f587504b
This reverts https://dart-review.googlesource.com/c/sdk/+/306674 Patchset 1 is a pure rollback of the rollback. Patchset 2 is https://dart-review.googlesource.com/c/sdk/+/306316 Patchset 4+ is the forward fix for the Fuchsia issues. The Fuchsia bug that we're fixing (or working around), is that VirtualMemory::DuplicateRX doesn't work on Fuchsia. A proper fix will require special casing it, like on MacOS. In the mean time we can avoid using this function by only allowing one page of trampolines on Fuchsia. Unfortunately, when I removed the BSS stuff from the original CL, it was necessary to duplicate even the first page, so I've had to add that stuff back just for Fuchsia. Change-Id: Id42de78ee5de126bcc83bfa4148f6efb4045f976 Bug: https://github.com/dart-lang/sdk/issues/52579 Bug: https://buganizer.corp.google.com/issues/284959841 Fixes: https://github.com/dart-lang/sdk/issues/52581 TEST=CI, especially vm-fuchsia-release-x64-try Reviewed-on: https://dart-review.googlesource.com/c/sdk/+/306676 Reviewed-by: Ryan Macnak <rmacnak@google.com> Commit-Queue: Liam Appelbe <liama@google.com> Reviewed-by: Daco Harkes <dacoharkes@google.com>
35 lines
1,003 B
Dart
35 lines
1,003 B
Dart
// Copyright (c) 2022, 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.
|
|
|
|
import 'dart:ffi';
|
|
|
|
import 'package:expect/expect.dart';
|
|
|
|
void main() {
|
|
final a = <int>[];
|
|
final b = <int>[];
|
|
for (int i = 0; i < 10; ++i) {
|
|
// Several pointers for same call site.
|
|
a.add(
|
|
Pointer.fromFunction<Int Function()>(nativeToDartCallback, 0).address);
|
|
b.add(
|
|
Pointer.fromFunction<Int Function()>(nativeToDartCallback, 1).address);
|
|
}
|
|
|
|
ensureEqualEntries(a);
|
|
ensureEqualEntries(b);
|
|
|
|
// The two functions have different exceptional return and should have
|
|
// therefore a different ffi trampoline.
|
|
Expect.notEquals(a.first, b.first);
|
|
}
|
|
|
|
void ensureEqualEntries(List<int> entries) {
|
|
final first = entries.first;
|
|
for (int i = 1; i < entries.length; ++i) {
|
|
Expect.equals(first, entries[i]);
|
|
}
|
|
}
|
|
|
|
int nativeToDartCallback() => 42;
|