We can already clear an object with the blt, so try to do the same to support copying from one object backing store to another. Really this is just object -> object, which is not that useful yet, what we really want is two backing stores, but that will require some vma rework first, otherwise we are stuck with "tmp" objects. Signed-off-by: Matthew Auld <matthew.auld@intel.com> Cc: Joonas Lahtinen <joonas.lahtinen@linux.intel.com> Cc: Abdiel Janulgue <abdiel.janulgue@linux.intel.com> Reviewed-by: Chris Wilson <chris@chris-wilson.co.uk> Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk> Link: https://patchwork.freedesktop.org/patch/msgid/20190810174338.19810-1-chris@chris-wilson.co.uk
38 lines
984 B
C
38 lines
984 B
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 "gt/intel_engine_pool.h"
|
|
#include "i915_vma.h"
|
|
|
|
struct drm_i915_gem_object;
|
|
|
|
struct i915_vma *intel_emit_vma_fill_blt(struct intel_context *ce,
|
|
struct i915_vma *vma,
|
|
u32 value);
|
|
|
|
struct i915_vma *intel_emit_vma_copy_blt(struct intel_context *ce,
|
|
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
|