1c349dbc7Sjsg /* 2c349dbc7Sjsg * SPDX-License-Identifier: MIT 3c349dbc7Sjsg * 4c349dbc7Sjsg * Copyright © 2018 Intel Corporation 5c349dbc7Sjsg */ 6c349dbc7Sjsg 7c349dbc7Sjsg #ifndef __I915_SELFTESTS_IGT_SPINNER_H__ 8c349dbc7Sjsg #define __I915_SELFTESTS_IGT_SPINNER_H__ 9c349dbc7Sjsg 10c349dbc7Sjsg #include "gem/i915_gem_context.h" 11c349dbc7Sjsg #include "gt/intel_engine.h" 12c349dbc7Sjsg 13c349dbc7Sjsg #include "i915_drv.h" 14c349dbc7Sjsg #include "i915_request.h" 15c349dbc7Sjsg #include "i915_selftest.h" 16c349dbc7Sjsg 17c349dbc7Sjsg struct intel_gt; 18c349dbc7Sjsg 19c349dbc7Sjsg struct igt_spinner { 20c349dbc7Sjsg struct intel_gt *gt; 21c349dbc7Sjsg struct drm_i915_gem_object *hws; 22c349dbc7Sjsg struct drm_i915_gem_object *obj; 23*5ca02815Sjsg struct intel_context *ce; 24*5ca02815Sjsg struct i915_vma *hws_vma, *batch_vma; 25c349dbc7Sjsg u32 *batch; 26c349dbc7Sjsg void *seqno; 27c349dbc7Sjsg }; 28c349dbc7Sjsg 29c349dbc7Sjsg int igt_spinner_init(struct igt_spinner *spin, struct intel_gt *gt); 30*5ca02815Sjsg int igt_spinner_pin(struct igt_spinner *spin, 31*5ca02815Sjsg struct intel_context *ce, 32*5ca02815Sjsg struct i915_gem_ww_ctx *ww); 33c349dbc7Sjsg void igt_spinner_fini(struct igt_spinner *spin); 34c349dbc7Sjsg 35c349dbc7Sjsg struct i915_request * 36c349dbc7Sjsg igt_spinner_create_request(struct igt_spinner *spin, 37c349dbc7Sjsg struct intel_context *ce, 38c349dbc7Sjsg u32 arbitration_command); 39c349dbc7Sjsg void igt_spinner_end(struct igt_spinner *spin); 40c349dbc7Sjsg 41c349dbc7Sjsg bool igt_wait_for_spinner(struct igt_spinner *spin, struct i915_request *rq); 42c349dbc7Sjsg 43c349dbc7Sjsg #endif 44