xref: /linux/drivers/gpu/drm/amd/amdgpu/amdgpu_userq.h (revision b4ada0618eed0fbd1b1630f73deb048c592b06a1)
1 /* SPDX-License-Identifier: MIT */
2 /*
3  * Copyright 2023 Advanced Micro Devices, Inc.
4  *
5  * Permission is hereby granted, free of charge, to any person obtaining a
6  * copy of this software and associated documentation files (the "Software"),
7  * to deal in the Software without restriction, including without limitation
8  * the rights to use, copy, modify, merge, publish, distribute, sublicense,
9  * and/or sell copies of the Software, and to permit persons to whom the
10  * Software is furnished to do so, subject to the following conditions:
11  *
12  * The above copyright notice and this permission notice shall be included in
13  * all copies or substantial portions of the Software.
14  *
15  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
18  * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
19  * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
20  * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
21  * OTHER DEALINGS IN THE SOFTWARE.
22  *
23  */
24 
25 #ifndef AMDGPU_USERQ_H_
26 #define AMDGPU_USERQ_H_
27 #include "amdgpu_eviction_fence.h"
28 
29 #define AMDGPU_MAX_USERQ_COUNT 512
30 
31 #define to_ev_fence(f) container_of(f, struct amdgpu_eviction_fence, base)
32 #define uq_mgr_to_fpriv(u) container_of(u, struct amdgpu_fpriv, userq_mgr)
33 #define work_to_uq_mgr(w, name) container_of(w, struct amdgpu_userq_mgr, name)
34 
35 enum amdgpu_userq_state {
36 	AMDGPU_USERQ_STATE_UNMAPPED = 0,
37 	AMDGPU_USERQ_STATE_MAPPED,
38 	AMDGPU_USERQ_STATE_PREEMPTED,
39 	AMDGPU_USERQ_STATE_HUNG,
40 };
41 
42 struct amdgpu_mqd_prop;
43 
44 struct amdgpu_userq_obj {
45 	void		 *cpu_ptr;
46 	uint64_t	 gpu_addr;
47 	struct amdgpu_bo *obj;
48 };
49 
50 struct amdgpu_usermode_queue {
51 	int			queue_type;
52 	enum amdgpu_userq_state state;
53 	uint64_t		doorbell_handle;
54 	uint64_t		doorbell_index;
55 	uint64_t		flags;
56 	struct amdgpu_mqd_prop	*userq_prop;
57 	struct amdgpu_userq_mgr *userq_mgr;
58 	struct amdgpu_vm	*vm;
59 	struct amdgpu_userq_obj mqd;
60 	struct amdgpu_userq_obj	db_obj;
61 	struct amdgpu_userq_obj fw_obj;
62 	struct amdgpu_userq_obj wptr_obj;
63 	struct xarray		fence_drv_xa;
64 	struct amdgpu_userq_fence_driver *fence_drv;
65 	struct dma_fence	*last_fence;
66 	u32			xcp_id;
67 	int			priority;
68 	struct dentry		*debugfs_queue;
69 };
70 
71 struct amdgpu_userq_funcs {
72 	int (*mqd_create)(struct amdgpu_userq_mgr *uq_mgr,
73 			  struct drm_amdgpu_userq_in *args,
74 			  struct amdgpu_usermode_queue *queue);
75 	void (*mqd_destroy)(struct amdgpu_userq_mgr *uq_mgr,
76 			    struct amdgpu_usermode_queue *uq);
77 	int (*unmap)(struct amdgpu_userq_mgr *uq_mgr,
78 		     struct amdgpu_usermode_queue *queue);
79 	int (*map)(struct amdgpu_userq_mgr *uq_mgr,
80 		   struct amdgpu_usermode_queue *queue);
81 };
82 
83 /* Usermode queues for gfx */
84 struct amdgpu_userq_mgr {
85 	struct idr			userq_idr;
86 	struct mutex			userq_mutex;
87 	struct amdgpu_device		*adev;
88 	struct delayed_work		resume_work;
89 	struct list_head		list;
90 	struct drm_file			*file;
91 };
92 
93 struct amdgpu_db_info {
94 	uint64_t doorbell_handle;
95 	uint32_t queue_type;
96 	uint32_t doorbell_offset;
97 	struct amdgpu_userq_obj	*db_obj;
98 };
99 
100 int amdgpu_userq_ioctl(struct drm_device *dev, void *data, struct drm_file *filp);
101 
102 int amdgpu_userq_mgr_init(struct amdgpu_userq_mgr *userq_mgr, struct drm_file *file_priv,
103 			  struct amdgpu_device *adev);
104 
105 void amdgpu_userq_mgr_fini(struct amdgpu_userq_mgr *userq_mgr);
106 
107 int amdgpu_userq_create_object(struct amdgpu_userq_mgr *uq_mgr,
108 			       struct amdgpu_userq_obj *userq_obj,
109 			       int size);
110 
111 void amdgpu_userq_destroy_object(struct amdgpu_userq_mgr *uq_mgr,
112 				 struct amdgpu_userq_obj *userq_obj);
113 
114 void amdgpu_userq_evict(struct amdgpu_userq_mgr *uq_mgr,
115 			struct amdgpu_eviction_fence *ev_fence);
116 
117 int amdgpu_userq_active(struct amdgpu_userq_mgr *uq_mgr);
118 
119 void amdgpu_userq_ensure_ev_fence(struct amdgpu_userq_mgr *userq_mgr,
120 				  struct amdgpu_eviction_fence_mgr *evf_mgr);
121 
122 uint64_t amdgpu_userq_get_doorbell_index(struct amdgpu_userq_mgr *uq_mgr,
123 					 struct amdgpu_db_info *db_info,
124 					     struct drm_file *filp);
125 
126 u32 amdgpu_userq_get_supported_ip_mask(struct amdgpu_device *adev);
127 
128 int amdgpu_userq_suspend(struct amdgpu_device *adev);
129 int amdgpu_userq_resume(struct amdgpu_device *adev);
130 
131 int amdgpu_userq_stop_sched_for_enforce_isolation(struct amdgpu_device *adev,
132 						  u32 idx);
133 int amdgpu_userq_start_sched_for_enforce_isolation(struct amdgpu_device *adev,
134 						   u32 idx);
135 
136 #endif
137