17ec681f3Smrg/* 27ec681f3Smrg * Copyright © 2020 Intel Corporation 37ec681f3Smrg * 47ec681f3Smrg * Permission is hereby granted, free of charge, to any person obtaining a 57ec681f3Smrg * copy of this software and associated documentation files (the "Software"), 67ec681f3Smrg * to deal in the Software without restriction, including without limitation 77ec681f3Smrg * on the rights to use, copy, modify, merge, publish, distribute, sub 87ec681f3Smrg * license, and/or sell copies of the Software, and to permit persons to whom 97ec681f3Smrg * the Software is furnished to do so, subject to the following conditions: 107ec681f3Smrg * 117ec681f3Smrg * The above copyright notice and this permission notice (including the next 127ec681f3Smrg * paragraph) shall be included in all copies or substantial portions of the 137ec681f3Smrg * Software. 147ec681f3Smrg * 157ec681f3Smrg * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 167ec681f3Smrg * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 177ec681f3Smrg * FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT. IN NO EVENT SHALL 187ec681f3Smrg * THE AUTHOR(S) AND/OR THEIR SUPPLIERS BE LIABLE FOR ANY CLAIM, 197ec681f3Smrg * DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR 207ec681f3Smrg * OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE 217ec681f3Smrg * USE OR OTHER DEALINGS IN THE SOFTWARE. 227ec681f3Smrg */ 237ec681f3Smrg 247ec681f3Smrg#ifndef ANV_MEASURE_H 257ec681f3Smrg#define ANV_MEASURE_H 267ec681f3Smrg 277ec681f3Smrg#include "anv_private.h" 287ec681f3Smrg#include "common/intel_measure.h" 297ec681f3Smrg 307ec681f3Smrgvoid anv_measure_device_init(struct anv_physical_device *device); 317ec681f3Smrgvoid anv_measure_device_destroy(struct anv_physical_device *device); 327ec681f3Smrg 337ec681f3Smrgvoid anv_measure_init(struct anv_cmd_buffer *cmd_buffer); 347ec681f3Smrgvoid anv_measure_destroy(struct anv_cmd_buffer *cmd_buffer); 357ec681f3Smrgvoid anv_measure_reset(struct anv_cmd_buffer *cmd_buffer); 367ec681f3Smrg 377ec681f3Smrgvoid _anv_measure_snapshot(struct anv_cmd_buffer *cmd_buffer, 387ec681f3Smrg enum intel_measure_snapshot_type type, 397ec681f3Smrg const char *event_name, 407ec681f3Smrg uint32_t count); 417ec681f3Smrg 427ec681f3Smrg/* ends snapshots before command buffer submission */ 437ec681f3Smrgvoid _anv_measure_endcommandbuffer(struct anv_cmd_buffer *cmd_buffer); 447ec681f3Smrg 457ec681f3Smrg/* when measuring render passes, inserts a timestamp */ 467ec681f3Smrgvoid _anv_measure_beginrenderpass(struct anv_cmd_buffer *cmd_buffer); 477ec681f3Smrg 487ec681f3Smrg/* tracks frame progression */ 497ec681f3Smrgvoid anv_measure_acquire(struct anv_device *device); 507ec681f3Smrg 517ec681f3Smrg/* should be combined with endcommandbuffer */ 527ec681f3Smrgvoid _anv_measure_submit(struct anv_cmd_buffer *cmd_buffer); 537ec681f3Smrg 547ec681f3Smrgvoid 557ec681f3Smrg_anv_measure_add_secondary(struct anv_cmd_buffer *primary, 567ec681f3Smrg struct anv_cmd_buffer *secondary); 577ec681f3Smrg 587ec681f3Smrg#define anv_measure_snapshot(cmd_buffer, type, event_name, count) \ 597ec681f3Smrg if (unlikely(cmd_buffer->measure)) \ 607ec681f3Smrg _anv_measure_snapshot(cmd_buffer, type, event_name, count) 617ec681f3Smrg 627ec681f3Smrg#define anv_measure_endcommandbuffer(cmd_buffer) \ 637ec681f3Smrg if (unlikely(cmd_buffer->measure)) \ 647ec681f3Smrg _anv_measure_endcommandbuffer(cmd_buffer) 657ec681f3Smrg 667ec681f3Smrg#define anv_measure_beginrenderpass(cmd_buffer) \ 677ec681f3Smrg if (unlikely(cmd_buffer->measure)) \ 687ec681f3Smrg _anv_measure_beginrenderpass(cmd_buffer) 697ec681f3Smrg 707ec681f3Smrg#define anv_measure_submit(cmd_buffer) \ 717ec681f3Smrg if (unlikely(cmd_buffer->measure)) \ 727ec681f3Smrg _anv_measure_submit(cmd_buffer) 737ec681f3Smrg 747ec681f3Smrg#define anv_measure_add_secondary(primary, secondary) \ 757ec681f3Smrg if (unlikely(primary->measure)) \ 767ec681f3Smrg _anv_measure_add_secondary(primary, secondary) 777ec681f3Smrg 787ec681f3Smrg#endif /* ANV_MEASURE_H */ 79