This is the last part outside of selftests that still don't use the correct lock ordering of timeline->mutex vs resv_lock. With gem fixed, there are a few places that still get locking wrong: - gvt/scheduler.c - i915_perf.c - Most if not all selftests. Changes since v1: - Add intel_engine_pm_get/put() calls to fix use-after-free when using intel_engine_get_pool(). Signed-off-by: Maarten Lankhorst <maarten.lankhorst@linux.intel.com> Reviewed-by: Thomas Hellström <thomas.hellstrom@intel.com> Link: https://patchwork.freedesktop.org/patch/msgid/20200819140904.1708856-16-maarten.lankhorst@linux.intel.com Signed-off-by: Joonas Lahtinen <joonas.lahtinen@linux.intel.com>
40 lines
1.0 KiB
C
40 lines
1.0 KiB
C
/* SPDX-License-Identifier: MIT */
|
|
/*
|
|
* Copyright © 2019 Intel Corporation
|
|
*/
|
|
|
|
#ifndef __I915_GEM_OBJECT_BLT_H__
|
|
#define __I915_GEM_OBJECT_BLT_H__
|
|
|
|
#include <linux/types.h>
|
|
|
|
#include "gt/intel_context.h"
|
|
#include "gt/intel_engine_pm.h"
|
|
#include "i915_vma.h"
|
|
|
|
struct drm_i915_gem_object;
|
|
struct i915_gem_ww_ctx;
|
|
|
|
struct i915_vma *intel_emit_vma_fill_blt(struct intel_context *ce,
|
|
struct i915_vma *vma,
|
|
struct i915_gem_ww_ctx *ww,
|
|
u32 value);
|
|
|
|
struct i915_vma *intel_emit_vma_copy_blt(struct intel_context *ce,
|
|
struct i915_gem_ww_ctx *ww,
|
|
struct i915_vma *src,
|
|
struct i915_vma *dst);
|
|
|
|
int intel_emit_vma_mark_active(struct i915_vma *vma, struct i915_request *rq);
|
|
void intel_emit_vma_release(struct intel_context *ce, struct i915_vma *vma);
|
|
|
|
int i915_gem_object_fill_blt(struct drm_i915_gem_object *obj,
|
|
struct intel_context *ce,
|
|
u32 value);
|
|
|
|
int i915_gem_object_copy_blt(struct drm_i915_gem_object *src,
|
|
struct drm_i915_gem_object *dst,
|
|
struct intel_context *ce);
|
|
|
|
#endif
|