1 /* SPDX-License-Identifier: MIT */
2 /*
3  * Copyright © 2021 Intel Corporation
4  */
5 
6 #ifndef _XE_GGTT_H_
7 #define _XE_GGTT_H_
8 
9 #include "xe_ggtt_types.h"
10 
11 struct drm_printer;
12 
13 int xe_ggtt_init_early(struct xe_ggtt *ggtt);
14 int xe_ggtt_init(struct xe_ggtt *ggtt);
15 
16 struct xe_ggtt_node *xe_ggtt_node_init(struct xe_ggtt *ggtt);
17 void xe_ggtt_node_fini(struct xe_ggtt_node *node);
18 int xe_ggtt_node_insert_balloon(struct xe_ggtt_node *node,
19 				u64 start, u64 size);
20 void xe_ggtt_node_remove_balloon(struct xe_ggtt_node *node);
21 
22 int xe_ggtt_node_insert(struct xe_ggtt_node *node, u32 size, u32 align);
23 int xe_ggtt_node_insert_locked(struct xe_ggtt_node *node,
24 			       u32 size, u32 align, u32 mm_flags);
25 void xe_ggtt_node_remove(struct xe_ggtt_node *node, bool invalidate);
26 bool xe_ggtt_node_allocated(const struct xe_ggtt_node *node);
27 void xe_ggtt_map_bo(struct xe_ggtt *ggtt, struct xe_bo *bo);
28 int xe_ggtt_insert_bo(struct xe_ggtt *ggtt, struct xe_bo *bo);
29 int xe_ggtt_insert_bo_at(struct xe_ggtt *ggtt, struct xe_bo *bo,
30 			 u64 start, u64 end);
31 void xe_ggtt_remove_bo(struct xe_ggtt *ggtt, struct xe_bo *bo);
32 u64 xe_ggtt_largest_hole(struct xe_ggtt *ggtt, u64 alignment, u64 *spare);
33 
34 int xe_ggtt_dump(struct xe_ggtt *ggtt, struct drm_printer *p);
35 u64 xe_ggtt_print_holes(struct xe_ggtt *ggtt, u64 alignment, struct drm_printer *p);
36 
37 #ifdef CONFIG_PCI_IOV
38 void xe_ggtt_assign(const struct xe_ggtt_node *node, u16 vfid);
39 #endif
40 
41 #endif
42