From bae182cbc6adc8796154162a87fc54ae804e0469 Mon Sep 17 00:00:00 2001 From: Sebastien Hertz Date: Tue, 17 Dec 2013 10:42:03 +0100 Subject: Fix method tracing from command-line Transitions current thread to the new kWaitingForMethodTracingStart thread state when starting method tracing. Ensures there is a current thread when method tracing is stopped due to runtime shutdown. If the current thread has been detached, we now re-attach it. Note: we only do this if method tracing has been activated from command-line. Fixes instrumentation when forcing interpreter mode (-Xint) with method tracing enabled. Removes unused parameter from UnsafeLogFatalForThreadSuspendAllTimeout. Bug: https://code.google.com/p/android/issues/detail?id=72094 Bug: 11683397 Change-Id: I70f000fb46ddd95d6ad51ea0a8eee77697a045e9 --- test/304-method-tracing/src/Main.java | 48 +++++++++++++++++++++++++++++++++++ 1 file changed, 48 insertions(+) create mode 100644 test/304-method-tracing/src/Main.java (limited to 'test/304-method-tracing/src') diff --git a/test/304-method-tracing/src/Main.java b/test/304-method-tracing/src/Main.java new file mode 100644 index 0000000..25cee6d --- /dev/null +++ b/test/304-method-tracing/src/Main.java @@ -0,0 +1,48 @@ +/* + * Copyright (C) 2014 The Android Open Source Project + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +import java.util.ArrayList; + +public class Main { + static class ThreadRunnable implements Runnable { + public void run() { + for (int i = 0; i < 1000; ++i) { + doNothing(); + } + } + + private void doNothing() {} + } + + public static void main(String[] args) { + ArrayList threads = new ArrayList(); + for (int i = 0; i < 10; ++i) { + threads.add(new Thread(new ThreadRunnable(), "TestThread-" + i)); + } + + for (Thread t : threads) { + t.start(); + } + + for (Thread t : threads) { + try { + t.join(); + } catch (InterruptedException e) { + System.out.println("Thread " + t.getName() + " has been interrupted"); + } + } + } +} -- cgit v1.1