Run init on normal thread priority

Summary:
The default priority for AsyncTask is THREAD_PRIORITY_BACKGROUND which puts the thread in a limited cgroup that can utilize ~10% CPU time. Because the whole TTI depends on this task we should run it on a normal priority.

The priority will be reset for the nest task and this has been true since donut: https://github.com/android/platform_frameworks_base/blob/donut-release/core/java/android/os/AsyncTask.java

Reviewed By: astreet

Differential Revision: D3417232

fbshipit-source-id: e1e35f82b35b31ff7ebf4fc59509ca2df21e2bdd
This commit is contained in:
Alexander Blom 2016-06-13 05:49:30 -07:00 committed by Facebook Github Bot 4
parent c25e48abfc
commit 933e17949b
1 changed files with 7 additions and 0 deletions

View File

@ -26,6 +26,7 @@ import android.content.Intent;
import android.net.Uri; import android.net.Uri;
import android.os.AsyncTask; import android.os.AsyncTask;
import android.os.Bundle; import android.os.Bundle;
import android.os.Process;
import android.view.View; import android.view.View;
import com.facebook.common.logging.FLog; import com.facebook.common.logging.FLog;
@ -190,6 +191,12 @@ import static com.facebook.systrace.Systrace.TRACE_TAG_REACT_JAVA_BRIDGE;
@Override @Override
protected Result<ReactApplicationContext> doInBackground(ReactContextInitParams... params) { protected Result<ReactApplicationContext> doInBackground(ReactContextInitParams... params) {
// TODO(t11687218): Look over all threading
// Default priority is Process.THREAD_PRIORITY_BACKGROUND which means we'll be put in a cgroup
// that only has access to a small fraction of CPU time. The priority will be reset after
// this task finishes: https://android.googlesource.com/platform/frameworks/base/+/d630f105e8bc0021541aacb4dc6498a49048ecea/core/java/android/os/AsyncTask.java#256
Process.setThreadPriority(Process.THREAD_PRIORITY_DEFAULT);
Assertions.assertCondition(params != null && params.length > 0 && params[0] != null); Assertions.assertCondition(params != null && params.length > 0 && params[0] != null);
try { try {
JavaScriptExecutor jsExecutor = params[0].getJsExecutorFactory().create(); JavaScriptExecutor jsExecutor = params[0].getJsExecutorFactory().create();