154 lines
4.1 KiB
C
154 lines
4.1 KiB
C
/* SPDX-License-Identifier: MIT */
|
|
/*
|
|
* Copyright © 2014 Intel Corporation
|
|
*/
|
|
|
|
#ifndef __INTEL_LRC_H__
|
|
#define __INTEL_LRC_H__
|
|
|
|
#include "i915_priolist_types.h"
|
|
|
|
#include <linux/bitfield.h>
|
|
#include <linux/types.h>
|
|
|
|
#include "intel_context.h"
|
|
|
|
struct drm_i915_gem_object;
|
|
struct i915_gem_ww_ctx;
|
|
struct intel_engine_cs;
|
|
struct intel_ring;
|
|
struct kref;
|
|
|
|
/* At the start of the context image is its per-process HWS page */
|
|
#define LRC_PPHWSP_PN (0)
|
|
#define LRC_PPHWSP_SZ (1)
|
|
/* After the PPHWSP we have the logical state for the context */
|
|
#define LRC_STATE_PN (LRC_PPHWSP_PN + LRC_PPHWSP_SZ)
|
|
#define LRC_STATE_OFFSET (LRC_STATE_PN * PAGE_SIZE)
|
|
|
|
/* Space within PPHWSP reserved to be used as scratch */
|
|
#define LRC_PPHWSP_SCRATCH 0x34
|
|
#define LRC_PPHWSP_SCRATCH_ADDR (LRC_PPHWSP_SCRATCH * sizeof(u32))
|
|
|
|
void lrc_init_wa_ctx(struct intel_engine_cs *engine);
|
|
void lrc_fini_wa_ctx(struct intel_engine_cs *engine);
|
|
|
|
int lrc_alloc(struct intel_context *ce,
|
|
struct intel_engine_cs *engine);
|
|
void lrc_reset(struct intel_context *ce);
|
|
void lrc_fini(struct intel_context *ce);
|
|
void lrc_destroy(struct kref *kref);
|
|
|
|
int
|
|
lrc_pre_pin(struct intel_context *ce,
|
|
struct intel_engine_cs *engine,
|
|
struct i915_gem_ww_ctx *ww,
|
|
void **vaddr);
|
|
int
|
|
lrc_pin(struct intel_context *ce,
|
|
struct intel_engine_cs *engine,
|
|
void *vaddr);
|
|
void lrc_unpin(struct intel_context *ce);
|
|
void lrc_post_unpin(struct intel_context *ce);
|
|
|
|
void lrc_init_state(struct intel_context *ce,
|
|
struct intel_engine_cs *engine,
|
|
void *state);
|
|
|
|
void lrc_init_regs(const struct intel_context *ce,
|
|
const struct intel_engine_cs *engine,
|
|
bool clear);
|
|
void lrc_reset_regs(const struct intel_context *ce,
|
|
const struct intel_engine_cs *engine);
|
|
|
|
u32 lrc_update_regs(const struct intel_context *ce,
|
|
const struct intel_engine_cs *engine,
|
|
u32 head);
|
|
void lrc_update_offsets(struct intel_context *ce,
|
|
struct intel_engine_cs *engine);
|
|
|
|
void lrc_check_regs(const struct intel_context *ce,
|
|
const struct intel_engine_cs *engine,
|
|
const char *when);
|
|
|
|
void lrc_update_runtime(struct intel_context *ce);
|
|
|
|
enum {
|
|
INTEL_ADVANCED_CONTEXT = 0,
|
|
INTEL_LEGACY_32B_CONTEXT,
|
|
INTEL_ADVANCED_AD_CONTEXT,
|
|
INTEL_LEGACY_64B_CONTEXT
|
|
};
|
|
|
|
enum {
|
|
FAULT_AND_HANG = 0,
|
|
FAULT_AND_HALT, /* Debug only */
|
|
FAULT_AND_STREAM,
|
|
FAULT_AND_CONTINUE /* Unsupported */
|
|
};
|
|
|
|
#define CTX_GTT_ADDRESS_MASK GENMASK(31, 12)
|
|
#define GEN8_CTX_VALID (1 << 0)
|
|
#define GEN8_CTX_FORCE_PD_RESTORE (1 << 1)
|
|
#define GEN8_CTX_FORCE_RESTORE (1 << 2)
|
|
#define GEN8_CTX_L3LLC_COHERENT (1 << 5)
|
|
#define GEN8_CTX_PRIVILEGE (1 << 8)
|
|
#define GEN8_CTX_ADDRESSING_MODE_SHIFT 3
|
|
#define GEN12_CTX_PRIORITY_MASK GENMASK(10, 9)
|
|
#define GEN12_CTX_PRIORITY_HIGH FIELD_PREP(GEN12_CTX_PRIORITY_MASK, 2)
|
|
#define GEN12_CTX_PRIORITY_NORMAL FIELD_PREP(GEN12_CTX_PRIORITY_MASK, 1)
|
|
#define GEN12_CTX_PRIORITY_LOW FIELD_PREP(GEN12_CTX_PRIORITY_MASK, 0)
|
|
#define GEN8_CTX_ID_SHIFT 32
|
|
#define GEN8_CTX_ID_WIDTH 21
|
|
#define GEN11_SW_CTX_ID_SHIFT 37
|
|
#define GEN11_SW_CTX_ID_WIDTH 11
|
|
#define GEN11_ENGINE_CLASS_SHIFT 61
|
|
#define GEN11_ENGINE_CLASS_WIDTH 3
|
|
#define GEN11_ENGINE_INSTANCE_SHIFT 48
|
|
#define GEN11_ENGINE_INSTANCE_WIDTH 6
|
|
#define XEHP_SW_CTX_ID_SHIFT 39
|
|
#define XEHP_SW_CTX_ID_WIDTH 16
|
|
#define XEHP_SW_COUNTER_SHIFT 58
|
|
#define XEHP_SW_COUNTER_WIDTH 6
|
|
|
|
static inline u32 lrc_desc_priority(int prio)
|
|
{
|
|
if (prio > I915_PRIORITY_NORMAL)
|
|
return GEN12_CTX_PRIORITY_HIGH;
|
|
else if (prio < I915_PRIORITY_NORMAL)
|
|
return GEN12_CTX_PRIORITY_LOW;
|
|
else
|
|
return GEN12_CTX_PRIORITY_NORMAL;
|
|
}
|
|
|
|
static inline void lrc_runtime_start(struct intel_context *ce)
|
|
{
|
|
struct intel_context_stats *stats = &ce->stats;
|
|
|
|
if (intel_context_is_barrier(ce))
|
|
return;
|
|
|
|
if (stats->active)
|
|
return;
|
|
|
|
WRITE_ONCE(stats->active, intel_context_clock());
|
|
}
|
|
|
|
static inline void lrc_runtime_stop(struct intel_context *ce)
|
|
{
|
|
struct intel_context_stats *stats = &ce->stats;
|
|
|
|
if (!stats->active)
|
|
return;
|
|
|
|
lrc_update_runtime(ce);
|
|
WRITE_ONCE(stats->active, 0);
|
|
}
|
|
|
|
#define DG2_PREDICATE_RESULT_WA (PAGE_SIZE - sizeof(u64))
|
|
#define DG2_PREDICATE_RESULT_BB (2048)
|
|
|
|
u32 lrc_indirect_bb(const struct intel_context *ce);
|
|
|
|
#endif /* __INTEL_LRC_H__ */
|