.. meta:: :description: ROCm Compute Profiler performance model: Command processor (CP) :keywords: Omniperf, ROCm Compute Profiler, ROCm, profiler, tool, Instinct, accelerator, command, processor, fetcher, packet processor, CPF, CPC ********************** Command processor (CP) ********************** The command processor (CP) is responsible for interacting with the AMDGPU kernel driver -- the Linux kernel -- on the CPU and for interacting with user-space HSA clients when they submit commands to HSA queues. Basic tasks of the CP include reading commands (such as, corresponding to a kernel launch) out of :hsa-runtime-pdf:`HSA queues <68>`, scheduling work to subsequent parts of the scheduler pipeline, and marking kernels complete for synchronization events on the host. The command processor consists of two sub-components: * :ref:`Fetcher ` (CPF): Fetches commands out of memory to hand them over to the CPC for processing. * :ref:`Packet processor ` (CPC): Micro-controller running the command processing firmware that decodes the fetched commands and (for kernels) passes them to the :ref:`workgroup processors ` for scheduling. Before scheduling work to the accelerator, the command processor can first acquire a memory fence to ensure system consistency (:hsa-runtime-pdf:`Section 2.6.4 <91>`). After the work is complete, the command processor can apply a memory-release fence. Depending on the AMD CDNA™ accelerator under question, either of these operations *might* initiate a cache write-back or invalidation. Analyzing command processor performance is most interesting for kernels that you suspect to be limited by scheduling or launch rate. The command processor’s metrics therefore are focused on reporting, for example: * Utilization of the fetcher * Utilization of the packet processor, and decoding processing packets * Stalls in fetching and processing .. _cpf-metrics: Command processor fetcher (CPF) =============================== .. jinja:: cpf-metrics :file: _templates/metrics_table.j2 .. _cpc-metrics: Command processor packet processor (CPC) ======================================== .. jinja:: cpc-metrics :file: _templates/metrics_table.j2