mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2024-12-28 11:18:45 +07:00
39e2f501c1
This complex struct pulling in half the driver deserves its own isolation in preparation for intel_context becoming an outright complicated class of its own. In order to split this beast into its own header also requests splitting several of its dependent types and their dependencies into their own headers as well. v2: Add standalone compilation tests Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk> Reviewed-by: Tvrtko Ursulin <tvrtko.ursulin@intel.com> Link: https://patchwork.freedesktop.org/patch/msgid/20190308132522.21573-2-chris@chris-wilson.co.uk
48 lines
1017 B
C
48 lines
1017 B
C
/*
|
|
* SPDX-License-Identifier: MIT
|
|
*
|
|
* Copyright © 2019 Intel Corporation
|
|
*/
|
|
|
|
#ifndef __INTEL_CONTEXT_H__
|
|
#define __INTEL_CONTEXT_H__
|
|
|
|
#include "i915_gem_context_types.h"
|
|
#include "intel_context_types.h"
|
|
#include "intel_engine_types.h"
|
|
|
|
void intel_context_init(struct intel_context *ce,
|
|
struct i915_gem_context *ctx,
|
|
struct intel_engine_cs *engine);
|
|
|
|
static inline struct intel_context *
|
|
to_intel_context(struct i915_gem_context *ctx,
|
|
const struct intel_engine_cs *engine)
|
|
{
|
|
return &ctx->__engine[engine->id];
|
|
}
|
|
|
|
static inline struct intel_context *
|
|
intel_context_pin(struct i915_gem_context *ctx, struct intel_engine_cs *engine)
|
|
{
|
|
return engine->context_pin(engine, ctx);
|
|
}
|
|
|
|
static inline void __intel_context_pin(struct intel_context *ce)
|
|
{
|
|
GEM_BUG_ON(!ce->pin_count);
|
|
ce->pin_count++;
|
|
}
|
|
|
|
static inline void intel_context_unpin(struct intel_context *ce)
|
|
{
|
|
GEM_BUG_ON(!ce->pin_count);
|
|
if (--ce->pin_count)
|
|
return;
|
|
|
|
GEM_BUG_ON(!ce->ops);
|
|
ce->ops->unpin(ce);
|
|
}
|
|
|
|
#endif /* __INTEL_CONTEXT_H__ */
|