blob: c9132e6e7dc8bca9558d4750ccd2317ce66b5715 [file] [log] [blame]
/*
* Copyright (C) 2019 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 dalvik.system.VMRuntime;
import java.io.File;
import java.io.IOException;
import java.lang.reflect.Method;
public class Main {
public static void $noinline$hotnessCount() {}
public static void $noinline$hotnessCountWithLoop(int count) {
for (int i = 0; i < count; i++) {
$noinline$hotnessCount();
}
}
public static void main(String[] args) throws Exception {
System.loadLibrary(args[0]);
if (!isAotCompiled(Main.class, "main")) {
return;
}
String methodName = "$noinline$hotnessCount";
int initialValue = getHotnessCounter(Main.class, methodName);
File file = null;
try {
file = createTempFile();
String codePath = System.getenv("DEX_LOCATION") + "/2230-profile-save-hotness.jar";
VMRuntime.registerAppInfo(
"test.app",
file.getPath(),
file.getPath(),
new String[] {codePath},
VMRuntime.CODE_PATH_TYPE_PRIMARY_APK);
// Test that the profile saves an app method with a profiling info.
$noinline$hotnessCountWithLoop(100000);
ensureProfileProcessing();
Method appMethod = Main.class.getDeclaredMethod(methodName);
if (!presentInProfile(file.getPath(), appMethod)) {
System.out.println("App method not hot in profile " +
getHotnessCounter(Main.class, methodName));
}
// Hardcoded assumption that the hotness value is zero.
if (getHotnessCounter(Main.class, methodName) != 0) {
System.out.println("Hotness should be zero " +
getHotnessCounter(Main.class, methodName));
}
VMRuntime.resetJitCounters();
if (getHotnessCounter(Main.class, methodName) != initialValue) {
System.out.println(
"Expected " + initialValue +", got " + + getHotnessCounter(Main.class, methodName));
}
} finally {
if (file != null) {
file.delete();
}
}
}
// Checks if the profiles saver has the method as hot/warm.
public static native boolean presentInProfile(String profile, Method method);
// Ensures the profile saver does its usual processing.
public static native void ensureProfileProcessing();
public static native boolean isAotCompiled(Class<?> cls, String methodName);
public static native int getHotnessCounter(Class<?> cls, String methodName);
private static final String TEMP_FILE_NAME_PREFIX = "temp";
private static final String TEMP_FILE_NAME_SUFFIX = "-file";
private static File createTempFile() throws Exception {
try {
return File.createTempFile(TEMP_FILE_NAME_PREFIX, TEMP_FILE_NAME_SUFFIX);
} catch (IOException e) {
System.setProperty("java.io.tmpdir", "/data/local/tmp");
try {
return File.createTempFile(TEMP_FILE_NAME_PREFIX, TEMP_FILE_NAME_SUFFIX);
} catch (IOException e2) {
System.setProperty("java.io.tmpdir", "/sdcard");
return File.createTempFile(TEMP_FILE_NAME_PREFIX, TEMP_FILE_NAME_SUFFIX);
}
}
}
}