Estimar los tiempos de procesamiento de fotogramas de la CPU y la GPU (tiempos de fotogramas) es esencial para comprender el rendimiento de tu app y encontrar cuellos de botella. Cuando generas perfiles de una app con AGI, el Generador de perfiles del sistema proporciona datos de seguimiento que puedes usar para estimar la latencia de fotogramas.
Tiempos de CPU
En AGI, puedes ver las latencias de fotogramas de CPU totales y activas en el seguimiento de CPU de un perfil del sistema.
Tiempo de CPU total
Para medir el tiempo de CPU total empleado, selecciona el intervalo de tiempo que incluye el tiempo entre eventos de envío de fotogramas sucesivos. Los eventos de envío de fotogramas son eglSwapBuffers
(para OpenGL) y vkQueuePresentKHR
(para Vulkan).
Esta medición es una estimación del tiempo de CPU total,pero no representa necesariamente el tiempo de CPU activo. Por ejemplo, en las apps vinculadas a la GPU, la CPU puede esperar a que la GPU complete su trabajo antes de enviar un fotograma nuevo. Esto suele suceder cuando un evento dequeueBuffer
, eglSwapBuffer
(para OpenGL) o vkQueuePresent
(para Vulkan) ocupa una gran parte del tiempo de la CPU.
El tiempo de espera se incluye en el tiempo de CPU total, pero no en el tiempo de CPU activo.
Tiempo de CPU activo
El tiempo de CPU activo determina cuándo la CPU ejecuta el código de la app sin estar en estado inactivo.
Para medir el tiempo de CPU activo, consulta las porciones Running justo encima de los eventos de CPU. Cuenta todas las partes del seguimiento entre los dos eventos de envío de marcos que tienen el estado En ejecución. Asegúrate de incluir subprocesos en funcionamiento.
Otra forma de medir el tiempo de CPU activo es ver las porciones de la app en los segmentos de CPU. Estos segmentos se indican cuando la CPU está en ejecución y se corresponden con los segmentos Running.
Para ayudar a identificar porciones de app, puedes agregar marcadores ATrace a tu app. De esta manera, se mostrarán los marcadores en el seguimiento de CPU del Generador de perfiles del sistema.
Estima la latencia de fotogramas de GPU
Para estimar la latencia de fotogramas de la GPU, puedes usar porciones de GPU o contadores de GPU en el Generador de perfiles del sistema. La estimación es más precisa cuando se usan porciones de GPU.
Porciones de GPU
Si el Generador de perfiles del sistema tiene información de porciones de GPU disponible, puedes obtener información muy precisa de la latencia de fotogramas de la GPU si mides la cantidad total de tiempo que tu app pasa trabajando en tareas asociadas con un solo fotograma.
Dispositivos Malí
En los dispositivos Malí, las porciones de GPU tienen segmentos de fragmentos, no fragmentos y, en ocasiones, no fragmentos complementarios. En el caso de marcos menos complejos, el trabajo de un fragmento y el que no lo son es secuencial, por lo que se puede distinguir el trabajo de un fotograma del otro buscando espacios entre el trabajo activo de la GPU.
Como alternativa, si estás familiarizado con el trabajo que se envía a la GPU, identificar el patrón de los pases de renderización enviados proporciona información sobre cuándo comienza y finaliza un fotograma.
En el caso de las apps que tienen un flujo de trabajo de GPU más paralelizado, puedes obtener la latencia de fotogramas de la GPU buscando todos los fotogramas que tengan el mismo submissionID en el panel Selection para cada porción.
En el caso de las apps basadas en Vulkan, se pueden usar varios envíos para componer un fotograma. Realiza un seguimiento de los IDs de envío con el segmento de eventos de Vulkan, que contiene una porción para cada envío. Si seleccionas una porción de envío, se destacarán todas las porciones de actividad de GPU que correspondan al envío.
Dispositivos Adreno
En los dispositivos Adreno, los segmentos de GPU aparecen en el segmento de la cola de GPU 0 y siempre se representan de forma secuencial, de modo que puedes ver todas las porciones que representan los pases de renderización de un fotograma y usarlas para medir los tiempos de procesamiento de la GPU.
Es similar a la situación de Mali descrita anteriormente: si la app usa Vulkan, el segmento de eventos de Vulkan proporciona información sobre el trabajo que se envía para ejecutar el fotograma. Para destacar los pases de renderización, haz clic en las porciones de Vulkan Events que están asociadas con el fotograma.
Hay algunas situaciones en las que los límites de fotogramas de la GPU son más difíciles de distinguir debido a que la app está muy vinculada a la GPU. En estas situaciones, si estás familiarizado con el trabajo que se envía a la GPU, puedes identificar el patrón con el que se ejecutan los pases de renderización y determinar los límites de fotogramas a partir de esa información.
Contadores de GPU
Si la información de los fragmentos de GPU no está disponible en un seguimiento, puedes estimar la latencia de fotogramas de GPU con los seguimientos del contador de GPU.
Dispositivos Malí
En los dispositivos Mali, puedes usar el segmento Uso de GPU para estimar la latencia de fotogramas de una app que no requiere mucha GPU. Cuando las apps usan menos GPU, tienen períodos regulares de actividad de GPU alta y baja, en lugar de una actividad constante y alta. Para estimar la latencia de fotogramas de la GPU con el segmento de uso de GPU, mide la duración de los períodos de actividad alta en el segmento.
Si la app requiere más GPU, puedes usar los segmentos de fragmentos y no fragmentos para estimar la latencia de fotogramas de la GPU. Cuando buscas patrones en los niveles de actividad de los segmentos fragmentos y no fragmentos, puedes obtener una estimación aproximada de dónde se encuentran los límites de un fotograma y usarlo para medir la latencia de fotogramas de la GPU.
Dispositivos Adreno
En los dispositivos Adreno, si la app no requiere mucha GPU, puedes estimar los tiempos de fotogramas de GPU de la misma manera que lo haces con los dispositivos Malí de la sección anterior.
Si la app requiere más GPU, puedes usar los segmentos Instrucciones de Vertex por segundo y Instrucciones por segundo para fragmentos a fin de estimar la latencia de fotogramas de la GPU. Al buscar patrones en los niveles de actividad de estos segmentos, puedes obtener una estimación aproximada de dónde se encuentran los límites de un fotograma y usar esa información para medir la latencia de fotogramas de la GPU.
Estas otras ramas pueden proporcionar información similar:
- Vértices sombreados / segundo
- Fragmentos con sombreado / segundo
- Porcentaje de vértices de sombreado de tiempo
- Porcentaje de fragmentos de tiempo