diff options
author | Siva Velusamy <vsiva@google.com> | 2012-12-06 11:04:15 -0800 |
---|---|---|
committer | Gerrit Code Review <noreply-gerritcodereview@google.com> | 2012-12-06 11:04:16 -0800 |
commit | 995970cc98caa8d62c62a3d21b34d7e6dd2f4a8e (patch) | |
tree | c12dd1e3c3dd01309f18149791485a9db7714ac7 | |
parent | 28e56923b893874aaa37f1aa19735b26be8bb499 (diff) | |
parent | 2556d11918040b0f96bd8996b205bbffb874a7a6 (diff) | |
download | sdk-995970cc98caa8d62c62a3d21b34d7e6dd2f4a8e.zip sdk-995970cc98caa8d62c62a3d21b34d7e6dd2f4a8e.tar.gz sdk-995970cc98caa8d62c62a3d21b34d7e6dd2f4a8e.tar.bz2 |
Merge "Automatically enable graphics profiling if necessary"
-rw-r--r-- | ddms/libs/ddmuilib/src/com/android/ddmuilib/SysinfoPanel.java | 54 |
1 files changed, 54 insertions, 0 deletions
diff --git a/ddms/libs/ddmuilib/src/com/android/ddmuilib/SysinfoPanel.java b/ddms/libs/ddmuilib/src/com/android/ddmuilib/SysinfoPanel.java index c063818..8ba2171 100644 --- a/ddms/libs/ddmuilib/src/com/android/ddmuilib/SysinfoPanel.java +++ b/ddms/libs/ddmuilib/src/com/android/ddmuilib/SysinfoPanel.java @@ -19,14 +19,17 @@ package com.android.ddmuilib; import com.android.ddmlib.AdbCommandRejectedException; import com.android.ddmlib.Client; import com.android.ddmlib.ClientData; +import com.android.ddmlib.IDevice; import com.android.ddmlib.IShellOutputReceiver; import com.android.ddmlib.Log; +import com.android.ddmlib.NullOutputReceiver; import com.android.ddmlib.ShellCommandUnresponsiveException; import com.android.ddmlib.TimeoutException; import com.android.ddmuilib.SysinfoPanel.BugReportParser.GfxProfileData; import com.google.common.base.Splitter; import com.google.common.collect.Lists; +import org.eclipse.jface.dialogs.MessageDialog; import org.eclipse.swt.SWT; import org.eclipse.swt.custom.StackLayout; import org.eclipse.swt.events.SelectionAdapter; @@ -103,6 +106,9 @@ public class SysinfoPanel extends TablePanel implements IShellOutputReceiver { "Frame Render Time", }; + /** Shell property that controls whether graphics profiling is enabled or not. */ + private static final String PROP_GFX_PROFILING = "debug.hwui.profile"; //$NON-NLS-1$ + /** * Generates the dataset to display. * @@ -164,6 +170,23 @@ public class SysinfoPanel extends TablePanel implements IShellOutputReceiver { private void loadFromDevice() { clearDataSet(); + if (mMode == MODE_GFXINFO) { + boolean en = isGfxProfilingEnabled(); + if (!en) { + if (enableGfxProfiling()) { + MessageDialog.openInformation(Display.getCurrent().getActiveShell(), + "DDMS", + "Graphics profiling was enabled on the device.\n" + + "It may be necessary to relaunch your application to see profile information."); + } else { + MessageDialog.openError(Display.getCurrent().getActiveShell(), + "DDMS", + "Unexpected error enabling graphics profiling on device.\n"); + return; + } + } + } + final String command = getDumpsysCommand(mMode); if (command == null) { return; @@ -193,6 +216,37 @@ public class SysinfoPanel extends TablePanel implements IShellOutputReceiver { t.start(); } + private boolean isGfxProfilingEnabled() { + IDevice device = getCurrentDevice(); + if (device == null) { + return false; + } + + String prop; + try { + prop = device.getPropertySync(PROP_GFX_PROFILING); + return Boolean.valueOf(prop); + } catch (Exception e) { + return false; + } + } + + private boolean enableGfxProfiling() { + IDevice device = getCurrentDevice(); + if (device == null) { + return false; + } + + try { + device.executeShellCommand("setprop " + PROP_GFX_PROFILING + " true", + new NullOutputReceiver()); + } catch (Exception e) { + return false; + } + + return true; + } + private String getDumpsysCommand(int mode) { if (mode == MODE_GFXINFO) { Client c = getCurrentClient(); |