#include "xe_hw_engine.h"
#include <linux/nospec.h>
#include <drm/drm_managed.h>
#include <uapi/drm/xe_drm.h>
#include "regs/xe_engine_regs.h"
#include "regs/xe_gt_regs.h"
#include "xe_assert.h"
#include "xe_bo.h"
#include "xe_device.h"
#include "xe_execlist.h"
#include "xe_force_wake.h"
#include "xe_gsc.h"
#include "xe_gt.h"
#include "xe_gt_ccs_mode.h"
#include "xe_gt_printk.h"
#include "xe_gt_mcr.h"
#include "xe_gt_topology.h"
#include "xe_hw_engine_group.h"
#include "xe_hw_fence.h"
#include "xe_irq.h"
#include "xe_lrc.h"
#include "xe_macros.h"
#include "xe_mmio.h"
#include "xe_reg_sr.h"
#include "xe_reg_whitelist.h"
#include "xe_rtp.h"
#include "xe_sched_job.h"
#include "xe_sriov.h"
#include "xe_tuning.h"
#include "xe_uc_fw.h"
#include "xe_wa.h"
#define MAX_MMIO_BASES …
struct engine_info { … };
static const struct engine_info engine_infos[] = …;
static void hw_engine_fini(void *arg)
{ … }
void xe_hw_engine_mmio_write32(struct xe_hw_engine *hwe,
struct xe_reg reg, u32 val)
{ … }
u32 xe_hw_engine_mmio_read32(struct xe_hw_engine *hwe, struct xe_reg reg)
{ … }
void xe_hw_engine_enable_ring(struct xe_hw_engine *hwe)
{ … }
static bool xe_hw_engine_match_fixed_cslice_mode(const struct xe_gt *gt,
const struct xe_hw_engine *hwe)
{ … }
static bool xe_rtp_cfeg_wmtp_disabled(const struct xe_gt *gt,
const struct xe_hw_engine *hwe)
{ … }
void
xe_hw_engine_setup_default_lrc_state(struct xe_hw_engine *hwe)
{ … }
static void
hw_engine_setup_default_state(struct xe_hw_engine *hwe)
{ … }
static void hw_engine_init_early(struct xe_gt *gt, struct xe_hw_engine *hwe,
enum xe_hw_engine_id id)
{ … }
static int hw_engine_init(struct xe_gt *gt, struct xe_hw_engine *hwe,
enum xe_hw_engine_id id)
{ … }
static void hw_engine_setup_logical_mapping(struct xe_gt *gt)
{ … }
static void read_media_fuses(struct xe_gt *gt)
{ … }
static void read_copy_fuses(struct xe_gt *gt)
{ … }
static void read_compute_fuses_from_dss(struct xe_gt *gt)
{ … }
static void read_compute_fuses_from_reg(struct xe_gt *gt)
{ … }
static void read_compute_fuses(struct xe_gt *gt)
{ … }
static void check_gsc_availability(struct xe_gt *gt)
{ … }
int xe_hw_engines_init_early(struct xe_gt *gt)
{ … }
int xe_hw_engines_init(struct xe_gt *gt)
{ … }
void xe_hw_engine_handle_irq(struct xe_hw_engine *hwe, u16 intr_vec)
{ … }
static bool
is_slice_common_per_gslice(struct xe_device *xe)
{ … }
static void
xe_hw_engine_snapshot_instdone_capture(struct xe_hw_engine *hwe,
struct xe_hw_engine_snapshot *snapshot)
{ … }
struct xe_hw_engine_snapshot *
xe_hw_engine_snapshot_capture(struct xe_hw_engine *hwe)
{ … }
static void
xe_hw_engine_snapshot_instdone_print(struct xe_hw_engine_snapshot *snapshot, struct drm_printer *p)
{ … }
void xe_hw_engine_snapshot_print(struct xe_hw_engine_snapshot *snapshot,
struct drm_printer *p)
{ … }
void xe_hw_engine_snapshot_free(struct xe_hw_engine_snapshot *snapshot)
{ … }
void xe_hw_engine_print(struct xe_hw_engine *hwe, struct drm_printer *p)
{ … }
u32 xe_hw_engine_mask_per_class(struct xe_gt *gt,
enum xe_engine_class engine_class)
{ … }
bool xe_hw_engine_is_reserved(struct xe_hw_engine *hwe)
{ … }
const char *xe_hw_engine_class_to_str(enum xe_engine_class class)
{ … }
u64 xe_hw_engine_read_timestamp(struct xe_hw_engine *hwe)
{ … }
enum xe_force_wake_domains xe_hw_engine_to_fw_domain(struct xe_hw_engine *hwe)
{ … }
static const enum xe_engine_class user_to_xe_engine_class[] = …;
struct xe_hw_engine *
xe_hw_engine_lookup(struct xe_device *xe,
struct drm_xe_engine_class_instance eci)
{ … }