Linux Audio

Check our new training course

Loading...
Note: File does not exist in v6.2.
  1/* SPDX-License-Identifier: MIT */
  2/*
  3 * Copyright © 2020 Intel Corporation
  4 */
  5
  6#ifndef _XE_MIGRATE_
  7#define _XE_MIGRATE_
  8
  9#include <linux/types.h>
 10
 11struct dma_fence;
 12struct iosys_map;
 13struct ttm_resource;
 14
 15struct xe_bo;
 16struct xe_gt;
 17struct xe_exec_queue;
 18struct xe_migrate;
 19struct xe_migrate_pt_update;
 20struct xe_sync_entry;
 21struct xe_pt;
 22struct xe_tile;
 23struct xe_vm;
 24struct xe_vm_pgtable_update;
 25struct xe_vma;
 26
 27/**
 28 * struct xe_migrate_pt_update_ops - Callbacks for the
 29 * xe_migrate_update_pgtables() function.
 30 */
 31struct xe_migrate_pt_update_ops {
 32	/**
 33	 * @populate: Populate a command buffer or page-table with ptes.
 34	 * @pt_update: Embeddable callback argument.
 35	 * @tile: The tile for the current operation.
 36	 * @map: struct iosys_map into the memory to be populated.
 37	 * @pos: If @map is NULL, map into the memory to be populated.
 38	 * @ofs: qword offset into @map, unused if @map is NULL.
 39	 * @num_qwords: Number of qwords to write.
 40	 * @update: Information about the PTEs to be inserted.
 41	 *
 42	 * This interface is intended to be used as a callback into the
 43	 * page-table system to populate command buffers or shared
 44	 * page-tables with PTEs.
 45	 */
 46	void (*populate)(struct xe_migrate_pt_update *pt_update,
 47			 struct xe_tile *tile, struct iosys_map *map,
 48			 void *pos, u32 ofs, u32 num_qwords,
 49			 const struct xe_vm_pgtable_update *update);
 50	/**
 51	 * @clear: Clear a command buffer or page-table with ptes.
 52	 * @pt_update: Embeddable callback argument.
 53	 * @tile: The tile for the current operation.
 54	 * @map: struct iosys_map into the memory to be populated.
 55	 * @pos: If @map is NULL, map into the memory to be populated.
 56	 * @ofs: qword offset into @map, unused if @map is NULL.
 57	 * @num_qwords: Number of qwords to write.
 58	 * @update: Information about the PTEs to be inserted.
 59	 *
 60	 * This interface is intended to be used as a callback into the
 61	 * page-table system to populate command buffers or shared
 62	 * page-tables with PTEs.
 63	 */
 64	void (*clear)(struct xe_migrate_pt_update *pt_update,
 65		      struct xe_tile *tile, struct iosys_map *map,
 66		      void *pos, u32 ofs, u32 num_qwords,
 67		      const struct xe_vm_pgtable_update *update);
 68
 69	/**
 70	 * @pre_commit: Callback to be called just before arming the
 71	 * sched_job.
 72	 * @pt_update: Pointer to embeddable callback argument.
 73	 *
 74	 * Return: 0 on success, negative error code on error.
 75	 */
 76	int (*pre_commit)(struct xe_migrate_pt_update *pt_update);
 77};
 78
 79/**
 80 * struct xe_migrate_pt_update - Argument to the
 81 * struct xe_migrate_pt_update_ops callbacks.
 82 *
 83 * Intended to be subclassed to support additional arguments if necessary.
 84 */
 85struct xe_migrate_pt_update {
 86	/** @ops: Pointer to the struct xe_migrate_pt_update_ops callbacks */
 87	const struct xe_migrate_pt_update_ops *ops;
 88	/** @vops: VMA operations */
 89	struct xe_vma_ops *vops;
 90	/** @job: The job if a GPU page-table update. NULL otherwise */
 91	struct xe_sched_job *job;
 92	/** @tile_id: Tile ID of the update */
 93	u8 tile_id;
 94};
 95
 96struct xe_migrate *xe_migrate_init(struct xe_tile *tile);
 97
 98struct dma_fence *xe_migrate_copy(struct xe_migrate *m,
 99				  struct xe_bo *src_bo,
100				  struct xe_bo *dst_bo,
101				  struct ttm_resource *src,
102				  struct ttm_resource *dst,
103				  bool copy_only_ccs);
104
105#define XE_MIGRATE_CLEAR_FLAG_BO_DATA		BIT(0)
106#define XE_MIGRATE_CLEAR_FLAG_CCS_DATA		BIT(1)
107#define XE_MIGRATE_CLEAR_FLAG_FULL	(XE_MIGRATE_CLEAR_FLAG_BO_DATA | \
108					XE_MIGRATE_CLEAR_FLAG_CCS_DATA)
109struct dma_fence *xe_migrate_clear(struct xe_migrate *m,
110				   struct xe_bo *bo,
111				   struct ttm_resource *dst,
112				   u32 clear_flags);
113
114struct xe_vm *xe_migrate_get_vm(struct xe_migrate *m);
115
116struct dma_fence *
117xe_migrate_update_pgtables(struct xe_migrate *m,
118			   struct xe_migrate_pt_update *pt_update);
119
120void xe_migrate_wait(struct xe_migrate *m);
121
122struct xe_exec_queue *xe_tile_migrate_exec_queue(struct xe_tile *tile);
123#endif