]> Git Repo - linux.git/blob - drivers/gpu/drm/amd/amdgpu/amdgpu_gfx.h
drm/amdgpu: Move common code to amdgpu_gfx.c
[linux.git] / drivers / gpu / drm / amd / amdgpu / amdgpu_gfx.h
1 /*
2  * Copyright 2014 Advanced Micro Devices, Inc.
3  *
4  * Permission is hereby granted, free of charge, to any person obtaining a
5  * copy of this software and associated documentation files (the "Software"),
6  * to deal in the Software without restriction, including without limitation
7  * the rights to use, copy, modify, merge, publish, distribute, sublicense,
8  * and/or sell copies of the Software, and to permit persons to whom the
9  * Software is furnished to do so, subject to the following conditions:
10  *
11  * The above copyright notice and this permission notice shall be included in
12  * all copies or substantial portions of the Software.
13  *
14  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
15  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
16  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
17  * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
18  * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
19  * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
20  * OTHER DEALINGS IN THE SOFTWARE.
21  *
22  */
23
24 #ifndef __AMDGPU_GFX_H__
25 #define __AMDGPU_GFX_H__
26
27 /*
28  * GFX stuff
29  */
30 #include "clearstate_defs.h"
31 #include "amdgpu_ring.h"
32 #include "amdgpu_rlc.h"
33
34 /* GFX current status */
35 #define AMDGPU_GFX_NORMAL_MODE                  0x00000000L
36 #define AMDGPU_GFX_SAFE_MODE                    0x00000001L
37 #define AMDGPU_GFX_PG_DISABLED_MODE             0x00000002L
38 #define AMDGPU_GFX_CG_DISABLED_MODE             0x00000004L
39 #define AMDGPU_GFX_LBPW_DISABLED_MODE           0x00000008L
40
41 #define AMDGPU_MAX_GFX_QUEUES KGD_MAX_QUEUES
42 #define AMDGPU_MAX_COMPUTE_QUEUES KGD_MAX_QUEUES
43
44 struct amdgpu_mec {
45         struct amdgpu_bo        *hpd_eop_obj;
46         u64                     hpd_eop_gpu_addr;
47         struct amdgpu_bo        *mec_fw_obj;
48         u64                     mec_fw_gpu_addr;
49         u32 num_mec;
50         u32 num_pipe_per_mec;
51         u32 num_queue_per_pipe;
52         void                    *mqd_backup[AMDGPU_MAX_COMPUTE_RINGS + 1];
53
54         /* These are the resources for which amdgpu takes ownership */
55         DECLARE_BITMAP(queue_bitmap, AMDGPU_MAX_COMPUTE_QUEUES);
56 };
57
58 struct kiq_pm4_funcs {
59         /* Support ASIC-specific kiq pm4 packets*/
60         void (*kiq_set_resources)(struct amdgpu_ring *kiq_ring,
61                                         uint64_t queue_mask);
62         void (*kiq_map_queues)(struct amdgpu_ring *kiq_ring,
63                                         struct amdgpu_ring *ring);
64         void (*kiq_unmap_queues)(struct amdgpu_ring *kiq_ring,
65                                  struct amdgpu_ring *ring, bool reset);
66         void (*kiq_query_status)(struct amdgpu_ring *kiq_ring,
67                                         struct amdgpu_ring *ring,
68                                         u64 addr,
69                                         u64 seq);
70         /* Packet sizes */
71         int set_resources_size;
72         int map_queues_size;
73         int unmap_queues_size;
74         int query_status_size;
75 };
76
77 struct amdgpu_kiq {
78         u64                     eop_gpu_addr;
79         struct amdgpu_bo        *eop_obj;
80         spinlock_t              ring_lock;
81         struct amdgpu_ring      ring;
82         struct amdgpu_irq_src   irq;
83         const struct kiq_pm4_funcs *pmf;
84 };
85
86 /*
87  * GPU scratch registers structures, functions & helpers
88  */
89 struct amdgpu_scratch {
90         unsigned                num_reg;
91         uint32_t                reg_base;
92         uint32_t                free_mask;
93 };
94
95 /*
96  * GFX configurations
97  */
98 #define AMDGPU_GFX_MAX_SE 4
99 #define AMDGPU_GFX_MAX_SH_PER_SE 2
100
101 struct amdgpu_rb_config {
102         uint32_t rb_backend_disable;
103         uint32_t user_rb_backend_disable;
104         uint32_t raster_config;
105         uint32_t raster_config_1;
106 };
107
108 struct gb_addr_config {
109         uint16_t pipe_interleave_size;
110         uint8_t num_pipes;
111         uint8_t max_compress_frags;
112         uint8_t num_banks;
113         uint8_t num_se;
114         uint8_t num_rb_per_se;
115 };
116
117 struct amdgpu_gfx_config {
118         unsigned max_shader_engines;
119         unsigned max_tile_pipes;
120         unsigned max_cu_per_sh;
121         unsigned max_sh_per_se;
122         unsigned max_backends_per_se;
123         unsigned max_texture_channel_caches;
124         unsigned max_gprs;
125         unsigned max_gs_threads;
126         unsigned max_hw_contexts;
127         unsigned sc_prim_fifo_size_frontend;
128         unsigned sc_prim_fifo_size_backend;
129         unsigned sc_hiz_tile_fifo_size;
130         unsigned sc_earlyz_tile_fifo_size;
131
132         unsigned num_tile_pipes;
133         unsigned backend_enable_mask;
134         unsigned mem_max_burst_length_bytes;
135         unsigned mem_row_size_in_kb;
136         unsigned shader_engine_tile_size;
137         unsigned num_gpus;
138         unsigned multi_gpu_tile_size;
139         unsigned mc_arb_ramcfg;
140         unsigned gb_addr_config;
141         unsigned num_rbs;
142         unsigned gs_vgt_table_depth;
143         unsigned gs_prim_buffer_depth;
144
145         uint32_t tile_mode_array[32];
146         uint32_t macrotile_mode_array[16];
147
148         struct gb_addr_config gb_addr_config_fields;
149         struct amdgpu_rb_config rb_config[AMDGPU_GFX_MAX_SE][AMDGPU_GFX_MAX_SH_PER_SE];
150
151         /* gfx configure feature */
152         uint32_t double_offchip_lds_buf;
153         /* cached value of DB_DEBUG2 */
154         uint32_t db_debug2;
155         /* gfx10 specific config */
156         uint32_t num_sc_per_sh;
157         uint32_t num_packer_per_sc;
158         uint32_t pa_sc_tile_steering_override;
159 };
160
161 struct amdgpu_cu_info {
162         uint32_t simd_per_cu;
163         uint32_t max_waves_per_simd;
164         uint32_t wave_front_size;
165         uint32_t max_scratch_slots_per_cu;
166         uint32_t lds_size;
167
168         /* total active CU number */
169         uint32_t number;
170         uint32_t ao_cu_mask;
171         uint32_t ao_cu_bitmap[4][4];
172         uint32_t bitmap[4][4];
173 };
174
175 struct amdgpu_gfx_funcs {
176         /* get the gpu clock counter */
177         uint64_t (*get_gpu_clock_counter)(struct amdgpu_device *adev);
178         void (*select_se_sh)(struct amdgpu_device *adev, u32 se_num,
179                              u32 sh_num, u32 instance);
180         void (*read_wave_data)(struct amdgpu_device *adev, uint32_t simd,
181                                uint32_t wave, uint32_t *dst, int *no_fields);
182         void (*read_wave_vgprs)(struct amdgpu_device *adev, uint32_t simd,
183                                 uint32_t wave, uint32_t thread, uint32_t start,
184                                 uint32_t size, uint32_t *dst);
185         void (*read_wave_sgprs)(struct amdgpu_device *adev, uint32_t simd,
186                                 uint32_t wave, uint32_t start, uint32_t size,
187                                 uint32_t *dst);
188         void (*select_me_pipe_q)(struct amdgpu_device *adev, u32 me, u32 pipe,
189                                  u32 queue);
190 };
191
192 struct amdgpu_ngg_buf {
193         struct amdgpu_bo        *bo;
194         uint64_t                gpu_addr;
195         uint32_t                size;
196         uint32_t                bo_size;
197 };
198
199 enum {
200         NGG_PRIM = 0,
201         NGG_POS,
202         NGG_CNTL,
203         NGG_PARAM,
204         NGG_BUF_MAX
205 };
206
207 struct amdgpu_ngg {
208         struct amdgpu_ngg_buf   buf[NGG_BUF_MAX];
209         uint32_t                gds_reserve_addr;
210         uint32_t                gds_reserve_size;
211         bool                    init;
212 };
213
214 struct sq_work {
215         struct work_struct      work;
216         unsigned ih_data;
217 };
218
219 struct amdgpu_pfp {
220         struct amdgpu_bo                *pfp_fw_obj;
221         uint64_t                        pfp_fw_gpu_addr;
222         uint32_t                        *pfp_fw_ptr;
223 };
224
225 struct amdgpu_ce {
226         struct amdgpu_bo                *ce_fw_obj;
227         uint64_t                        ce_fw_gpu_addr;
228         uint32_t                        *ce_fw_ptr;
229 };
230
231 struct amdgpu_me {
232         struct amdgpu_bo                *me_fw_obj;
233         uint64_t                        me_fw_gpu_addr;
234         uint32_t                        *me_fw_ptr;
235         uint32_t                        num_me;
236         uint32_t                        num_pipe_per_me;
237         uint32_t                        num_queue_per_pipe;
238         void                            *mqd_backup[AMDGPU_MAX_GFX_RINGS + 1];
239
240         /* These are the resources for which amdgpu takes ownership */
241         DECLARE_BITMAP(queue_bitmap, AMDGPU_MAX_GFX_QUEUES);
242 };
243
244 struct amdgpu_gfx {
245         struct mutex                    gpu_clock_mutex;
246         struct amdgpu_gfx_config        config;
247         struct amdgpu_rlc               rlc;
248         struct amdgpu_pfp               pfp;
249         struct amdgpu_ce                ce;
250         struct amdgpu_me                me;
251         struct amdgpu_mec               mec;
252         struct amdgpu_kiq               kiq;
253         struct amdgpu_scratch           scratch;
254         const struct firmware           *me_fw; /* ME firmware */
255         uint32_t                        me_fw_version;
256         const struct firmware           *pfp_fw; /* PFP firmware */
257         uint32_t                        pfp_fw_version;
258         const struct firmware           *ce_fw; /* CE firmware */
259         uint32_t                        ce_fw_version;
260         const struct firmware           *rlc_fw; /* RLC firmware */
261         uint32_t                        rlc_fw_version;
262         const struct firmware           *mec_fw; /* MEC firmware */
263         uint32_t                        mec_fw_version;
264         const struct firmware           *mec2_fw; /* MEC2 firmware */
265         uint32_t                        mec2_fw_version;
266         uint32_t                        me_feature_version;
267         uint32_t                        ce_feature_version;
268         uint32_t                        pfp_feature_version;
269         uint32_t                        rlc_feature_version;
270         uint32_t                        rlc_srlc_fw_version;
271         uint32_t                        rlc_srlc_feature_version;
272         uint32_t                        rlc_srlg_fw_version;
273         uint32_t                        rlc_srlg_feature_version;
274         uint32_t                        rlc_srls_fw_version;
275         uint32_t                        rlc_srls_feature_version;
276         uint32_t                        mec_feature_version;
277         uint32_t                        mec2_feature_version;
278         bool                            mec_fw_write_wait;
279         bool                            me_fw_write_wait;
280         struct amdgpu_ring              gfx_ring[AMDGPU_MAX_GFX_RINGS];
281         unsigned                        num_gfx_rings;
282         struct amdgpu_ring              compute_ring[AMDGPU_MAX_COMPUTE_RINGS];
283         unsigned                        num_compute_rings;
284         struct amdgpu_irq_src           eop_irq;
285         struct amdgpu_irq_src           priv_reg_irq;
286         struct amdgpu_irq_src           priv_inst_irq;
287         struct amdgpu_irq_src           cp_ecc_error_irq;
288         struct amdgpu_irq_src           sq_irq;
289         struct sq_work                  sq_work;
290
291         /* gfx status */
292         uint32_t                        gfx_current_status;
293         /* ce ram size*/
294         unsigned                        ce_ram_size;
295         struct amdgpu_cu_info           cu_info;
296         const struct amdgpu_gfx_funcs   *funcs;
297
298         /* reset mask */
299         uint32_t                        grbm_soft_reset;
300         uint32_t                        srbm_soft_reset;
301
302         /* NGG */
303         struct amdgpu_ngg               ngg;
304
305         /* gfx off */
306         bool                            gfx_off_state; /* true: enabled, false: disabled */
307         struct mutex                    gfx_off_mutex;
308         uint32_t                        gfx_off_req_count; /* default 1, enable gfx off: dec 1, disable gfx off: add 1 */
309         struct delayed_work             gfx_off_delay_work;
310
311         /* pipe reservation */
312         struct mutex                    pipe_reserve_mutex;
313         DECLARE_BITMAP                  (pipe_reserve_bitmap, AMDGPU_MAX_COMPUTE_QUEUES);
314
315         /*ras */
316         struct ras_common_if            *ras_if;
317 };
318
319 #define amdgpu_gfx_get_gpu_clock_counter(adev) (adev)->gfx.funcs->get_gpu_clock_counter((adev))
320 #define amdgpu_gfx_select_se_sh(adev, se, sh, instance) (adev)->gfx.funcs->select_se_sh((adev), (se), (sh), (instance))
321 #define amdgpu_gfx_select_me_pipe_q(adev, me, pipe, q) (adev)->gfx.funcs->select_me_pipe_q((adev), (me), (pipe), (q))
322
323 /**
324  * amdgpu_gfx_create_bitmask - create a bitmask
325  *
326  * @bit_width: length of the mask
327  *
328  * create a variable length bit mask.
329  * Returns the bitmask.
330  */
331 static inline u32 amdgpu_gfx_create_bitmask(u32 bit_width)
332 {
333         return (u32)((1ULL << bit_width) - 1);
334 }
335
336 int amdgpu_gfx_scratch_get(struct amdgpu_device *adev, uint32_t *reg);
337 void amdgpu_gfx_scratch_free(struct amdgpu_device *adev, uint32_t reg);
338
339 void amdgpu_gfx_parse_disable_cu(unsigned *mask, unsigned max_se,
340                                  unsigned max_sh);
341
342 int amdgpu_gfx_kiq_init_ring(struct amdgpu_device *adev,
343                              struct amdgpu_ring *ring,
344                              struct amdgpu_irq_src *irq);
345
346 void amdgpu_gfx_kiq_free_ring(struct amdgpu_ring *ring,
347                               struct amdgpu_irq_src *irq);
348
349 void amdgpu_gfx_kiq_fini(struct amdgpu_device *adev);
350 int amdgpu_gfx_kiq_init(struct amdgpu_device *adev,
351                         unsigned hpd_size);
352
353 int amdgpu_gfx_mqd_sw_init(struct amdgpu_device *adev,
354                            unsigned mqd_size);
355 void amdgpu_gfx_mqd_sw_fini(struct amdgpu_device *adev);
356 int amdgpu_gfx_disable_kcq(struct amdgpu_device *adev);
357 int amdgpu_gfx_enable_kcq(struct amdgpu_device *adev);
358
359 void amdgpu_gfx_compute_queue_acquire(struct amdgpu_device *adev);
360 void amdgpu_gfx_graphics_queue_acquire(struct amdgpu_device *adev);
361
362 int amdgpu_gfx_mec_queue_to_bit(struct amdgpu_device *adev, int mec,
363                                 int pipe, int queue);
364 void amdgpu_gfx_bit_to_mec_queue(struct amdgpu_device *adev, int bit,
365                                  int *mec, int *pipe, int *queue);
366 bool amdgpu_gfx_is_mec_queue_enabled(struct amdgpu_device *adev, int mec,
367                                      int pipe, int queue);
368 int amdgpu_gfx_me_queue_to_bit(struct amdgpu_device *adev, int me,
369                                int pipe, int queue);
370 void amdgpu_gfx_bit_to_me_queue(struct amdgpu_device *adev, int bit,
371                                 int *me, int *pipe, int *queue);
372 bool amdgpu_gfx_is_me_queue_enabled(struct amdgpu_device *adev, int me,
373                                     int pipe, int queue);
374 void amdgpu_gfx_off_ctrl(struct amdgpu_device *adev, bool enable);
375
376 #endif
This page took 0.058311 seconds and 4 git commands to generate.