]> Git Repo - linux.git/blob - drivers/gpu/drm/amd/amdgpu/amdgpu_device.c
Revert "drm/amdgpu: support access regs outside of mmio bar"
[linux.git] / drivers / gpu / drm / amd / amdgpu / amdgpu_device.c
1 /*
2  * Copyright 2008 Advanced Micro Devices, Inc.
3  * Copyright 2008 Red Hat Inc.
4  * Copyright 2009 Jerome Glisse.
5  *
6  * Permission is hereby granted, free of charge, to any person obtaining a
7  * copy of this software and associated documentation files (the "Software"),
8  * to deal in the Software without restriction, including without limitation
9  * the rights to use, copy, modify, merge, publish, distribute, sublicense,
10  * and/or sell copies of the Software, and to permit persons to whom the
11  * Software is furnished to do so, subject to the following conditions:
12  *
13  * The above copyright notice and this permission notice shall be included in
14  * all copies or substantial portions of the Software.
15  *
16  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
19  * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
20  * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
21  * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
22  * OTHER DEALINGS IN THE SOFTWARE.
23  *
24  * Authors: Dave Airlie
25  *          Alex Deucher
26  *          Jerome Glisse
27  */
28 #include <linux/power_supply.h>
29 #include <linux/kthread.h>
30 #include <linux/module.h>
31 #include <linux/console.h>
32 #include <linux/slab.h>
33
34 #include <drm/drm_atomic_helper.h>
35 #include <drm/drm_probe_helper.h>
36 #include <drm/amdgpu_drm.h>
37 #include <linux/vgaarb.h>
38 #include <linux/vga_switcheroo.h>
39 #include <linux/efi.h>
40 #include "amdgpu.h"
41 #include "amdgpu_trace.h"
42 #include "amdgpu_i2c.h"
43 #include "atom.h"
44 #include "amdgpu_atombios.h"
45 #include "amdgpu_atomfirmware.h"
46 #include "amd_pcie.h"
47 #ifdef CONFIG_DRM_AMDGPU_SI
48 #include "si.h"
49 #endif
50 #ifdef CONFIG_DRM_AMDGPU_CIK
51 #include "cik.h"
52 #endif
53 #include "vi.h"
54 #include "soc15.h"
55 #include "nv.h"
56 #include "bif/bif_4_1_d.h"
57 #include <linux/pci.h>
58 #include <linux/firmware.h>
59 #include "amdgpu_vf_error.h"
60
61 #include "amdgpu_amdkfd.h"
62 #include "amdgpu_pm.h"
63
64 #include "amdgpu_xgmi.h"
65 #include "amdgpu_ras.h"
66 #include "amdgpu_pmu.h"
67 #include "amdgpu_fru_eeprom.h"
68
69 #include <linux/suspend.h>
70 #include <drm/task_barrier.h>
71 #include <linux/pm_runtime.h>
72
73 MODULE_FIRMWARE("amdgpu/vega10_gpu_info.bin");
74 MODULE_FIRMWARE("amdgpu/vega12_gpu_info.bin");
75 MODULE_FIRMWARE("amdgpu/raven_gpu_info.bin");
76 MODULE_FIRMWARE("amdgpu/picasso_gpu_info.bin");
77 MODULE_FIRMWARE("amdgpu/raven2_gpu_info.bin");
78 MODULE_FIRMWARE("amdgpu/arcturus_gpu_info.bin");
79 MODULE_FIRMWARE("amdgpu/renoir_gpu_info.bin");
80 MODULE_FIRMWARE("amdgpu/navi10_gpu_info.bin");
81 MODULE_FIRMWARE("amdgpu/navi14_gpu_info.bin");
82 MODULE_FIRMWARE("amdgpu/navi12_gpu_info.bin");
83 MODULE_FIRMWARE("amdgpu/sienna_cichlid_gpu_info.bin");
84
85 #define AMDGPU_RESUME_MS                2000
86
87 const char *amdgpu_asic_name[] = {
88         "TAHITI",
89         "PITCAIRN",
90         "VERDE",
91         "OLAND",
92         "HAINAN",
93         "BONAIRE",
94         "KAVERI",
95         "KABINI",
96         "HAWAII",
97         "MULLINS",
98         "TOPAZ",
99         "TONGA",
100         "FIJI",
101         "CARRIZO",
102         "STONEY",
103         "POLARIS10",
104         "POLARIS11",
105         "POLARIS12",
106         "VEGAM",
107         "VEGA10",
108         "VEGA12",
109         "VEGA20",
110         "RAVEN",
111         "ARCTURUS",
112         "RENOIR",
113         "NAVI10",
114         "NAVI14",
115         "NAVI12",
116         "SIENNA_CICHLID",
117         "LAST",
118 };
119
120 /**
121  * DOC: pcie_replay_count
122  *
123  * The amdgpu driver provides a sysfs API for reporting the total number
124  * of PCIe replays (NAKs)
125  * The file pcie_replay_count is used for this and returns the total
126  * number of replays as a sum of the NAKs generated and NAKs received
127  */
128
129 static ssize_t amdgpu_device_get_pcie_replay_count(struct device *dev,
130                 struct device_attribute *attr, char *buf)
131 {
132         struct drm_device *ddev = dev_get_drvdata(dev);
133         struct amdgpu_device *adev = ddev->dev_private;
134         uint64_t cnt = amdgpu_asic_get_pcie_replay_count(adev);
135
136         return snprintf(buf, PAGE_SIZE, "%llu\n", cnt);
137 }
138
139 static DEVICE_ATTR(pcie_replay_count, S_IRUGO,
140                 amdgpu_device_get_pcie_replay_count, NULL);
141
142 static void amdgpu_device_get_pcie_info(struct amdgpu_device *adev);
143
144 /**
145  * DOC: product_name
146  *
147  * The amdgpu driver provides a sysfs API for reporting the product name
148  * for the device
149  * The file serial_number is used for this and returns the product name
150  * as returned from the FRU.
151  * NOTE: This is only available for certain server cards
152  */
153
154 static ssize_t amdgpu_device_get_product_name(struct device *dev,
155                 struct device_attribute *attr, char *buf)
156 {
157         struct drm_device *ddev = dev_get_drvdata(dev);
158         struct amdgpu_device *adev = ddev->dev_private;
159
160         return snprintf(buf, PAGE_SIZE, "%s\n", adev->product_name);
161 }
162
163 static DEVICE_ATTR(product_name, S_IRUGO,
164                 amdgpu_device_get_product_name, NULL);
165
166 /**
167  * DOC: product_number
168  *
169  * The amdgpu driver provides a sysfs API for reporting the part number
170  * for the device
171  * The file serial_number is used for this and returns the part number
172  * as returned from the FRU.
173  * NOTE: This is only available for certain server cards
174  */
175
176 static ssize_t amdgpu_device_get_product_number(struct device *dev,
177                 struct device_attribute *attr, char *buf)
178 {
179         struct drm_device *ddev = dev_get_drvdata(dev);
180         struct amdgpu_device *adev = ddev->dev_private;
181
182         return snprintf(buf, PAGE_SIZE, "%s\n", adev->product_number);
183 }
184
185 static DEVICE_ATTR(product_number, S_IRUGO,
186                 amdgpu_device_get_product_number, NULL);
187
188 /**
189  * DOC: serial_number
190  *
191  * The amdgpu driver provides a sysfs API for reporting the serial number
192  * for the device
193  * The file serial_number is used for this and returns the serial number
194  * as returned from the FRU.
195  * NOTE: This is only available for certain server cards
196  */
197
198 static ssize_t amdgpu_device_get_serial_number(struct device *dev,
199                 struct device_attribute *attr, char *buf)
200 {
201         struct drm_device *ddev = dev_get_drvdata(dev);
202         struct amdgpu_device *adev = ddev->dev_private;
203
204         return snprintf(buf, PAGE_SIZE, "%s\n", adev->serial);
205 }
206
207 static DEVICE_ATTR(serial_number, S_IRUGO,
208                 amdgpu_device_get_serial_number, NULL);
209
210 /**
211  * amdgpu_device_supports_boco - Is the device a dGPU with HG/PX power control
212  *
213  * @dev: drm_device pointer
214  *
215  * Returns true if the device is a dGPU with HG/PX power control,
216  * otherwise return false.
217  */
218 bool amdgpu_device_supports_boco(struct drm_device *dev)
219 {
220         struct amdgpu_device *adev = dev->dev_private;
221
222         if (adev->flags & AMD_IS_PX)
223                 return true;
224         return false;
225 }
226
227 /**
228  * amdgpu_device_supports_baco - Does the device support BACO
229  *
230  * @dev: drm_device pointer
231  *
232  * Returns true if the device supporte BACO,
233  * otherwise return false.
234  */
235 bool amdgpu_device_supports_baco(struct drm_device *dev)
236 {
237         struct amdgpu_device *adev = dev->dev_private;
238
239         return amdgpu_asic_supports_baco(adev);
240 }
241
242 /**
243  * VRAM access helper functions.
244  *
245  * amdgpu_device_vram_access - read/write a buffer in vram
246  *
247  * @adev: amdgpu_device pointer
248  * @pos: offset of the buffer in vram
249  * @buf: virtual address of the buffer in system memory
250  * @size: read/write size, sizeof(@buf) must > @size
251  * @write: true - write to vram, otherwise - read from vram
252  */
253 void amdgpu_device_vram_access(struct amdgpu_device *adev, loff_t pos,
254                                uint32_t *buf, size_t size, bool write)
255 {
256         unsigned long flags;
257         uint32_t hi = ~0;
258         uint64_t last;
259
260
261 #ifdef CONFIG_64BIT
262         last = min(pos + size, adev->gmc.visible_vram_size);
263         if (last > pos) {
264                 void __iomem *addr = adev->mman.aper_base_kaddr + pos;
265                 size_t count = last - pos;
266
267                 if (write) {
268                         memcpy_toio(addr, buf, count);
269                         mb();
270                         amdgpu_asic_flush_hdp(adev, NULL);
271                 } else {
272                         amdgpu_asic_invalidate_hdp(adev, NULL);
273                         mb();
274                         memcpy_fromio(buf, addr, count);
275                 }
276
277                 if (count == size)
278                         return;
279
280                 pos += count;
281                 buf += count / 4;
282                 size -= count;
283         }
284 #endif
285
286         spin_lock_irqsave(&adev->mmio_idx_lock, flags);
287         for (last = pos + size; pos < last; pos += 4) {
288                 uint32_t tmp = pos >> 31;
289
290                 WREG32_NO_KIQ(mmMM_INDEX, ((uint32_t)pos) | 0x80000000);
291                 if (tmp != hi) {
292                         WREG32_NO_KIQ(mmMM_INDEX_HI, tmp);
293                         hi = tmp;
294                 }
295                 if (write)
296                         WREG32_NO_KIQ(mmMM_DATA, *buf++);
297                 else
298                         *buf++ = RREG32_NO_KIQ(mmMM_DATA);
299         }
300         spin_unlock_irqrestore(&adev->mmio_idx_lock, flags);
301 }
302
303 /*
304  * MMIO register access helper functions.
305  */
306 /**
307  * amdgpu_mm_rreg - read a memory mapped IO register
308  *
309  * @adev: amdgpu_device pointer
310  * @reg: dword aligned register offset
311  * @acc_flags: access flags which require special behavior
312  *
313  * Returns the 32 bit value from the offset specified.
314  */
315 uint32_t amdgpu_mm_rreg(struct amdgpu_device *adev, uint32_t reg,
316                         uint32_t acc_flags)
317 {
318         uint32_t ret;
319
320         if (!(acc_flags & AMDGPU_REGS_NO_KIQ) && amdgpu_sriov_runtime(adev))
321                 return amdgpu_kiq_rreg(adev, reg);
322
323         if ((reg * 4) < adev->rmmio_size)
324                 ret = readl(((void __iomem *)adev->rmmio) + (reg * 4));
325         else {
326                 unsigned long flags;
327
328                 spin_lock_irqsave(&adev->mmio_idx_lock, flags);
329                 writel((reg * 4), ((void __iomem *)adev->rmmio) + (mmMM_INDEX * 4));
330                 ret = readl(((void __iomem *)adev->rmmio) + (mmMM_DATA * 4));
331                 spin_unlock_irqrestore(&adev->mmio_idx_lock, flags);
332         }
333         trace_amdgpu_mm_rreg(adev->pdev->device, reg, ret);
334         return ret;
335 }
336
337 /*
338  * MMIO register read with bytes helper functions
339  * @offset:bytes offset from MMIO start
340  *
341 */
342
343 /**
344  * amdgpu_mm_rreg8 - read a memory mapped IO register
345  *
346  * @adev: amdgpu_device pointer
347  * @offset: byte aligned register offset
348  *
349  * Returns the 8 bit value from the offset specified.
350  */
351 uint8_t amdgpu_mm_rreg8(struct amdgpu_device *adev, uint32_t offset) {
352         if (offset < adev->rmmio_size)
353                 return (readb(adev->rmmio + offset));
354         BUG();
355 }
356
357 /*
358  * MMIO register write with bytes helper functions
359  * @offset:bytes offset from MMIO start
360  * @value: the value want to be written to the register
361  *
362 */
363 /**
364  * amdgpu_mm_wreg8 - read a memory mapped IO register
365  *
366  * @adev: amdgpu_device pointer
367  * @offset: byte aligned register offset
368  * @value: 8 bit value to write
369  *
370  * Writes the value specified to the offset specified.
371  */
372 void amdgpu_mm_wreg8(struct amdgpu_device *adev, uint32_t offset, uint8_t value) {
373         if (offset < adev->rmmio_size)
374                 writeb(value, adev->rmmio + offset);
375         else
376                 BUG();
377 }
378
379 void static inline amdgpu_mm_wreg_mmio(struct amdgpu_device *adev, uint32_t reg, uint32_t v, uint32_t acc_flags)
380 {
381         trace_amdgpu_mm_wreg(adev->pdev->device, reg, v);
382
383         if ((reg * 4) < adev->rmmio_size)
384                 writel(v, ((void __iomem *)adev->rmmio) + (reg * 4));
385         else {
386                 unsigned long flags;
387
388                 spin_lock_irqsave(&adev->mmio_idx_lock, flags);
389                 writel((reg * 4), ((void __iomem *)adev->rmmio) + (mmMM_INDEX * 4));
390                 writel(v, ((void __iomem *)adev->rmmio) + (mmMM_DATA * 4));
391                 spin_unlock_irqrestore(&adev->mmio_idx_lock, flags);
392         }
393 }
394
395 /**
396  * amdgpu_mm_wreg - write to a memory mapped IO register
397  *
398  * @adev: amdgpu_device pointer
399  * @reg: dword aligned register offset
400  * @v: 32 bit value to write to the register
401  * @acc_flags: access flags which require special behavior
402  *
403  * Writes the value specified to the offset specified.
404  */
405 void amdgpu_mm_wreg(struct amdgpu_device *adev, uint32_t reg, uint32_t v,
406                     uint32_t acc_flags)
407 {
408         if (!(acc_flags & AMDGPU_REGS_NO_KIQ) && amdgpu_sriov_runtime(adev))
409                 return amdgpu_kiq_wreg(adev, reg, v);
410
411         amdgpu_mm_wreg_mmio(adev, reg, v, acc_flags);
412 }
413
414 /*
415  * amdgpu_mm_wreg_mmio_rlc -  write register either with mmio or with RLC path if in range
416  *
417  * this function is invoked only the debugfs register access
418  * */
419 void amdgpu_mm_wreg_mmio_rlc(struct amdgpu_device *adev, uint32_t reg, uint32_t v,
420                     uint32_t acc_flags)
421 {
422         if (amdgpu_sriov_fullaccess(adev) &&
423                 adev->gfx.rlc.funcs &&
424                 adev->gfx.rlc.funcs->is_rlcg_access_range) {
425
426                 if (adev->gfx.rlc.funcs->is_rlcg_access_range(adev, reg))
427                         return adev->gfx.rlc.funcs->rlcg_wreg(adev, reg, v);
428         }
429
430         amdgpu_mm_wreg_mmio(adev, reg, v, acc_flags);
431 }
432
433 /**
434  * amdgpu_io_rreg - read an IO register
435  *
436  * @adev: amdgpu_device pointer
437  * @reg: dword aligned register offset
438  *
439  * Returns the 32 bit value from the offset specified.
440  */
441 u32 amdgpu_io_rreg(struct amdgpu_device *adev, u32 reg)
442 {
443         if ((reg * 4) < adev->rio_mem_size)
444                 return ioread32(adev->rio_mem + (reg * 4));
445         else {
446                 iowrite32((reg * 4), adev->rio_mem + (mmMM_INDEX * 4));
447                 return ioread32(adev->rio_mem + (mmMM_DATA * 4));
448         }
449 }
450
451 /**
452  * amdgpu_io_wreg - write to an IO register
453  *
454  * @adev: amdgpu_device pointer
455  * @reg: dword aligned register offset
456  * @v: 32 bit value to write to the register
457  *
458  * Writes the value specified to the offset specified.
459  */
460 void amdgpu_io_wreg(struct amdgpu_device *adev, u32 reg, u32 v)
461 {
462         if ((reg * 4) < adev->rio_mem_size)
463                 iowrite32(v, adev->rio_mem + (reg * 4));
464         else {
465                 iowrite32((reg * 4), adev->rio_mem + (mmMM_INDEX * 4));
466                 iowrite32(v, adev->rio_mem + (mmMM_DATA * 4));
467         }
468 }
469
470 /**
471  * amdgpu_mm_rdoorbell - read a doorbell dword
472  *
473  * @adev: amdgpu_device pointer
474  * @index: doorbell index
475  *
476  * Returns the value in the doorbell aperture at the
477  * requested doorbell index (CIK).
478  */
479 u32 amdgpu_mm_rdoorbell(struct amdgpu_device *adev, u32 index)
480 {
481         if (index < adev->doorbell.num_doorbells) {
482                 return readl(adev->doorbell.ptr + index);
483         } else {
484                 DRM_ERROR("reading beyond doorbell aperture: 0x%08x!\n", index);
485                 return 0;
486         }
487 }
488
489 /**
490  * amdgpu_mm_wdoorbell - write a doorbell dword
491  *
492  * @adev: amdgpu_device pointer
493  * @index: doorbell index
494  * @v: value to write
495  *
496  * Writes @v to the doorbell aperture at the
497  * requested doorbell index (CIK).
498  */
499 void amdgpu_mm_wdoorbell(struct amdgpu_device *adev, u32 index, u32 v)
500 {
501         if (index < adev->doorbell.num_doorbells) {
502                 writel(v, adev->doorbell.ptr + index);
503         } else {
504                 DRM_ERROR("writing beyond doorbell aperture: 0x%08x!\n", index);
505         }
506 }
507
508 /**
509  * amdgpu_mm_rdoorbell64 - read a doorbell Qword
510  *
511  * @adev: amdgpu_device pointer
512  * @index: doorbell index
513  *
514  * Returns the value in the doorbell aperture at the
515  * requested doorbell index (VEGA10+).
516  */
517 u64 amdgpu_mm_rdoorbell64(struct amdgpu_device *adev, u32 index)
518 {
519         if (index < adev->doorbell.num_doorbells) {
520                 return atomic64_read((atomic64_t *)(adev->doorbell.ptr + index));
521         } else {
522                 DRM_ERROR("reading beyond doorbell aperture: 0x%08x!\n", index);
523                 return 0;
524         }
525 }
526
527 /**
528  * amdgpu_mm_wdoorbell64 - write a doorbell Qword
529  *
530  * @adev: amdgpu_device pointer
531  * @index: doorbell index
532  * @v: value to write
533  *
534  * Writes @v to the doorbell aperture at the
535  * requested doorbell index (VEGA10+).
536  */
537 void amdgpu_mm_wdoorbell64(struct amdgpu_device *adev, u32 index, u64 v)
538 {
539         if (index < adev->doorbell.num_doorbells) {
540                 atomic64_set((atomic64_t *)(adev->doorbell.ptr + index), v);
541         } else {
542                 DRM_ERROR("writing beyond doorbell aperture: 0x%08x!\n", index);
543         }
544 }
545
546 /**
547  * amdgpu_invalid_rreg - dummy reg read function
548  *
549  * @adev: amdgpu device pointer
550  * @reg: offset of register
551  *
552  * Dummy register read function.  Used for register blocks
553  * that certain asics don't have (all asics).
554  * Returns the value in the register.
555  */
556 static uint32_t amdgpu_invalid_rreg(struct amdgpu_device *adev, uint32_t reg)
557 {
558         DRM_ERROR("Invalid callback to read register 0x%04X\n", reg);
559         BUG();
560         return 0;
561 }
562
563 /**
564  * amdgpu_invalid_wreg - dummy reg write function
565  *
566  * @adev: amdgpu device pointer
567  * @reg: offset of register
568  * @v: value to write to the register
569  *
570  * Dummy register read function.  Used for register blocks
571  * that certain asics don't have (all asics).
572  */
573 static void amdgpu_invalid_wreg(struct amdgpu_device *adev, uint32_t reg, uint32_t v)
574 {
575         DRM_ERROR("Invalid callback to write register 0x%04X with 0x%08X\n",
576                   reg, v);
577         BUG();
578 }
579
580 /**
581  * amdgpu_invalid_rreg64 - dummy 64 bit reg read function
582  *
583  * @adev: amdgpu device pointer
584  * @reg: offset of register
585  *
586  * Dummy register read function.  Used for register blocks
587  * that certain asics don't have (all asics).
588  * Returns the value in the register.
589  */
590 static uint64_t amdgpu_invalid_rreg64(struct amdgpu_device *adev, uint32_t reg)
591 {
592         DRM_ERROR("Invalid callback to read 64 bit register 0x%04X\n", reg);
593         BUG();
594         return 0;
595 }
596
597 /**
598  * amdgpu_invalid_wreg64 - dummy reg write function
599  *
600  * @adev: amdgpu device pointer
601  * @reg: offset of register
602  * @v: value to write to the register
603  *
604  * Dummy register read function.  Used for register blocks
605  * that certain asics don't have (all asics).
606  */
607 static void amdgpu_invalid_wreg64(struct amdgpu_device *adev, uint32_t reg, uint64_t v)
608 {
609         DRM_ERROR("Invalid callback to write 64 bit register 0x%04X with 0x%08llX\n",
610                   reg, v);
611         BUG();
612 }
613
614 /**
615  * amdgpu_block_invalid_rreg - dummy reg read function
616  *
617  * @adev: amdgpu device pointer
618  * @block: offset of instance
619  * @reg: offset of register
620  *
621  * Dummy register read function.  Used for register blocks
622  * that certain asics don't have (all asics).
623  * Returns the value in the register.
624  */
625 static uint32_t amdgpu_block_invalid_rreg(struct amdgpu_device *adev,
626                                           uint32_t block, uint32_t reg)
627 {
628         DRM_ERROR("Invalid callback to read register 0x%04X in block 0x%04X\n",
629                   reg, block);
630         BUG();
631         return 0;
632 }
633
634 /**
635  * amdgpu_block_invalid_wreg - dummy reg write function
636  *
637  * @adev: amdgpu device pointer
638  * @block: offset of instance
639  * @reg: offset of register
640  * @v: value to write to the register
641  *
642  * Dummy register read function.  Used for register blocks
643  * that certain asics don't have (all asics).
644  */
645 static void amdgpu_block_invalid_wreg(struct amdgpu_device *adev,
646                                       uint32_t block,
647                                       uint32_t reg, uint32_t v)
648 {
649         DRM_ERROR("Invalid block callback to write register 0x%04X in block 0x%04X with 0x%08X\n",
650                   reg, block, v);
651         BUG();
652 }
653
654 /**
655  * amdgpu_device_vram_scratch_init - allocate the VRAM scratch page
656  *
657  * @adev: amdgpu device pointer
658  *
659  * Allocates a scratch page of VRAM for use by various things in the
660  * driver.
661  */
662 static int amdgpu_device_vram_scratch_init(struct amdgpu_device *adev)
663 {
664         return amdgpu_bo_create_kernel(adev, AMDGPU_GPU_PAGE_SIZE,
665                                        PAGE_SIZE, AMDGPU_GEM_DOMAIN_VRAM,
666                                        &adev->vram_scratch.robj,
667                                        &adev->vram_scratch.gpu_addr,
668                                        (void **)&adev->vram_scratch.ptr);
669 }
670
671 /**
672  * amdgpu_device_vram_scratch_fini - Free the VRAM scratch page
673  *
674  * @adev: amdgpu device pointer
675  *
676  * Frees the VRAM scratch page.
677  */
678 static void amdgpu_device_vram_scratch_fini(struct amdgpu_device *adev)
679 {
680         amdgpu_bo_free_kernel(&adev->vram_scratch.robj, NULL, NULL);
681 }
682
683 /**
684  * amdgpu_device_program_register_sequence - program an array of registers.
685  *
686  * @adev: amdgpu_device pointer
687  * @registers: pointer to the register array
688  * @array_size: size of the register array
689  *
690  * Programs an array or registers with and and or masks.
691  * This is a helper for setting golden registers.
692  */
693 void amdgpu_device_program_register_sequence(struct amdgpu_device *adev,
694                                              const u32 *registers,
695                                              const u32 array_size)
696 {
697         u32 tmp, reg, and_mask, or_mask;
698         int i;
699
700         if (array_size % 3)
701                 return;
702
703         for (i = 0; i < array_size; i +=3) {
704                 reg = registers[i + 0];
705                 and_mask = registers[i + 1];
706                 or_mask = registers[i + 2];
707
708                 if (and_mask == 0xffffffff) {
709                         tmp = or_mask;
710                 } else {
711                         tmp = RREG32(reg);
712                         tmp &= ~and_mask;
713                         if (adev->family >= AMDGPU_FAMILY_AI)
714                                 tmp |= (or_mask & and_mask);
715                         else
716                                 tmp |= or_mask;
717                 }
718                 WREG32(reg, tmp);
719         }
720 }
721
722 /**
723  * amdgpu_device_pci_config_reset - reset the GPU
724  *
725  * @adev: amdgpu_device pointer
726  *
727  * Resets the GPU using the pci config reset sequence.
728  * Only applicable to asics prior to vega10.
729  */
730 void amdgpu_device_pci_config_reset(struct amdgpu_device *adev)
731 {
732         pci_write_config_dword(adev->pdev, 0x7c, AMDGPU_ASIC_RESET_DATA);
733 }
734
735 /*
736  * GPU doorbell aperture helpers function.
737  */
738 /**
739  * amdgpu_device_doorbell_init - Init doorbell driver information.
740  *
741  * @adev: amdgpu_device pointer
742  *
743  * Init doorbell driver information (CIK)
744  * Returns 0 on success, error on failure.
745  */
746 static int amdgpu_device_doorbell_init(struct amdgpu_device *adev)
747 {
748
749         /* No doorbell on SI hardware generation */
750         if (adev->asic_type < CHIP_BONAIRE) {
751                 adev->doorbell.base = 0;
752                 adev->doorbell.size = 0;
753                 adev->doorbell.num_doorbells = 0;
754                 adev->doorbell.ptr = NULL;
755                 return 0;
756         }
757
758         if (pci_resource_flags(adev->pdev, 2) & IORESOURCE_UNSET)
759                 return -EINVAL;
760
761         amdgpu_asic_init_doorbell_index(adev);
762
763         /* doorbell bar mapping */
764         adev->doorbell.base = pci_resource_start(adev->pdev, 2);
765         adev->doorbell.size = pci_resource_len(adev->pdev, 2);
766
767         adev->doorbell.num_doorbells = min_t(u32, adev->doorbell.size / sizeof(u32),
768                                              adev->doorbell_index.max_assignment+1);
769         if (adev->doorbell.num_doorbells == 0)
770                 return -EINVAL;
771
772         /* For Vega, reserve and map two pages on doorbell BAR since SDMA
773          * paging queue doorbell use the second page. The
774          * AMDGPU_DOORBELL64_MAX_ASSIGNMENT definition assumes all the
775          * doorbells are in the first page. So with paging queue enabled,
776          * the max num_doorbells should + 1 page (0x400 in dword)
777          */
778         if (adev->asic_type >= CHIP_VEGA10)
779                 adev->doorbell.num_doorbells += 0x400;
780
781         adev->doorbell.ptr = ioremap(adev->doorbell.base,
782                                      adev->doorbell.num_doorbells *
783                                      sizeof(u32));
784         if (adev->doorbell.ptr == NULL)
785                 return -ENOMEM;
786
787         return 0;
788 }
789
790 /**
791  * amdgpu_device_doorbell_fini - Tear down doorbell driver information.
792  *
793  * @adev: amdgpu_device pointer
794  *
795  * Tear down doorbell driver information (CIK)
796  */
797 static void amdgpu_device_doorbell_fini(struct amdgpu_device *adev)
798 {
799         iounmap(adev->doorbell.ptr);
800         adev->doorbell.ptr = NULL;
801 }
802
803
804
805 /*
806  * amdgpu_device_wb_*()
807  * Writeback is the method by which the GPU updates special pages in memory
808  * with the status of certain GPU events (fences, ring pointers,etc.).
809  */
810
811 /**
812  * amdgpu_device_wb_fini - Disable Writeback and free memory
813  *
814  * @adev: amdgpu_device pointer
815  *
816  * Disables Writeback and frees the Writeback memory (all asics).
817  * Used at driver shutdown.
818  */
819 static void amdgpu_device_wb_fini(struct amdgpu_device *adev)
820 {
821         if (adev->wb.wb_obj) {
822                 amdgpu_bo_free_kernel(&adev->wb.wb_obj,
823                                       &adev->wb.gpu_addr,
824                                       (void **)&adev->wb.wb);
825                 adev->wb.wb_obj = NULL;
826         }
827 }
828
829 /**
830  * amdgpu_device_wb_init- Init Writeback driver info and allocate memory
831  *
832  * @adev: amdgpu_device pointer
833  *
834  * Initializes writeback and allocates writeback memory (all asics).
835  * Used at driver startup.
836  * Returns 0 on success or an -error on failure.
837  */
838 static int amdgpu_device_wb_init(struct amdgpu_device *adev)
839 {
840         int r;
841
842         if (adev->wb.wb_obj == NULL) {
843                 /* AMDGPU_MAX_WB * sizeof(uint32_t) * 8 = AMDGPU_MAX_WB 256bit slots */
844                 r = amdgpu_bo_create_kernel(adev, AMDGPU_MAX_WB * sizeof(uint32_t) * 8,
845                                             PAGE_SIZE, AMDGPU_GEM_DOMAIN_GTT,
846                                             &adev->wb.wb_obj, &adev->wb.gpu_addr,
847                                             (void **)&adev->wb.wb);
848                 if (r) {
849                         dev_warn(adev->dev, "(%d) create WB bo failed\n", r);
850                         return r;
851                 }
852
853                 adev->wb.num_wb = AMDGPU_MAX_WB;
854                 memset(&adev->wb.used, 0, sizeof(adev->wb.used));
855
856                 /* clear wb memory */
857                 memset((char *)adev->wb.wb, 0, AMDGPU_MAX_WB * sizeof(uint32_t) * 8);
858         }
859
860         return 0;
861 }
862
863 /**
864  * amdgpu_device_wb_get - Allocate a wb entry
865  *
866  * @adev: amdgpu_device pointer
867  * @wb: wb index
868  *
869  * Allocate a wb slot for use by the driver (all asics).
870  * Returns 0 on success or -EINVAL on failure.
871  */
872 int amdgpu_device_wb_get(struct amdgpu_device *adev, u32 *wb)
873 {
874         unsigned long offset = find_first_zero_bit(adev->wb.used, adev->wb.num_wb);
875
876         if (offset < adev->wb.num_wb) {
877                 __set_bit(offset, adev->wb.used);
878                 *wb = offset << 3; /* convert to dw offset */
879                 return 0;
880         } else {
881                 return -EINVAL;
882         }
883 }
884
885 /**
886  * amdgpu_device_wb_free - Free a wb entry
887  *
888  * @adev: amdgpu_device pointer
889  * @wb: wb index
890  *
891  * Free a wb slot allocated for use by the driver (all asics)
892  */
893 void amdgpu_device_wb_free(struct amdgpu_device *adev, u32 wb)
894 {
895         wb >>= 3;
896         if (wb < adev->wb.num_wb)
897                 __clear_bit(wb, adev->wb.used);
898 }
899
900 /**
901  * amdgpu_device_resize_fb_bar - try to resize FB BAR
902  *
903  * @adev: amdgpu_device pointer
904  *
905  * Try to resize FB BAR to make all VRAM CPU accessible. We try very hard not
906  * to fail, but if any of the BARs is not accessible after the size we abort
907  * driver loading by returning -ENODEV.
908  */
909 int amdgpu_device_resize_fb_bar(struct amdgpu_device *adev)
910 {
911         u64 space_needed = roundup_pow_of_two(adev->gmc.real_vram_size);
912         u32 rbar_size = order_base_2(((space_needed >> 20) | 1)) - 1;
913         struct pci_bus *root;
914         struct resource *res;
915         unsigned i;
916         u16 cmd;
917         int r;
918
919         /* Bypass for VF */
920         if (amdgpu_sriov_vf(adev))
921                 return 0;
922
923         /* skip if the bios has already enabled large BAR */
924         if (adev->gmc.real_vram_size &&
925             (pci_resource_len(adev->pdev, 0) >= adev->gmc.real_vram_size))
926                 return 0;
927
928         /* Check if the root BUS has 64bit memory resources */
929         root = adev->pdev->bus;
930         while (root->parent)
931                 root = root->parent;
932
933         pci_bus_for_each_resource(root, res, i) {
934                 if (res && res->flags & (IORESOURCE_MEM | IORESOURCE_MEM_64) &&
935                     res->start > 0x100000000ull)
936                         break;
937         }
938
939         /* Trying to resize is pointless without a root hub window above 4GB */
940         if (!res)
941                 return 0;
942
943         /* Disable memory decoding while we change the BAR addresses and size */
944         pci_read_config_word(adev->pdev, PCI_COMMAND, &cmd);
945         pci_write_config_word(adev->pdev, PCI_COMMAND,
946                               cmd & ~PCI_COMMAND_MEMORY);
947
948         /* Free the VRAM and doorbell BAR, we most likely need to move both. */
949         amdgpu_device_doorbell_fini(adev);
950         if (adev->asic_type >= CHIP_BONAIRE)
951                 pci_release_resource(adev->pdev, 2);
952
953         pci_release_resource(adev->pdev, 0);
954
955         r = pci_resize_resource(adev->pdev, 0, rbar_size);
956         if (r == -ENOSPC)
957                 DRM_INFO("Not enough PCI address space for a large BAR.");
958         else if (r && r != -ENOTSUPP)
959                 DRM_ERROR("Problem resizing BAR0 (%d).", r);
960
961         pci_assign_unassigned_bus_resources(adev->pdev->bus);
962
963         /* When the doorbell or fb BAR isn't available we have no chance of
964          * using the device.
965          */
966         r = amdgpu_device_doorbell_init(adev);
967         if (r || (pci_resource_flags(adev->pdev, 0) & IORESOURCE_UNSET))
968                 return -ENODEV;
969
970         pci_write_config_word(adev->pdev, PCI_COMMAND, cmd);
971
972         return 0;
973 }
974
975 /*
976  * GPU helpers function.
977  */
978 /**
979  * amdgpu_device_need_post - check if the hw need post or not
980  *
981  * @adev: amdgpu_device pointer
982  *
983  * Check if the asic has been initialized (all asics) at driver startup
984  * or post is needed if  hw reset is performed.
985  * Returns true if need or false if not.
986  */
987 bool amdgpu_device_need_post(struct amdgpu_device *adev)
988 {
989         uint32_t reg;
990
991         if (amdgpu_sriov_vf(adev))
992                 return false;
993
994         if (amdgpu_passthrough(adev)) {
995                 /* for FIJI: In whole GPU pass-through virtualization case, after VM reboot
996                  * some old smc fw still need driver do vPost otherwise gpu hang, while
997                  * those smc fw version above 22.15 doesn't have this flaw, so we force
998                  * vpost executed for smc version below 22.15
999                  */
1000                 if (adev->asic_type == CHIP_FIJI) {
1001                         int err;
1002                         uint32_t fw_ver;
1003                         err = request_firmware(&adev->pm.fw, "amdgpu/fiji_smc.bin", adev->dev);
1004                         /* force vPost if error occured */
1005                         if (err)
1006                                 return true;
1007
1008                         fw_ver = *((uint32_t *)adev->pm.fw->data + 69);
1009                         if (fw_ver < 0x00160e00)
1010                                 return true;
1011                 }
1012         }
1013
1014         if (adev->has_hw_reset) {
1015                 adev->has_hw_reset = false;
1016                 return true;
1017         }
1018
1019         /* bios scratch used on CIK+ */
1020         if (adev->asic_type >= CHIP_BONAIRE)
1021                 return amdgpu_atombios_scratch_need_asic_init(adev);
1022
1023         /* check MEM_SIZE for older asics */
1024         reg = amdgpu_asic_get_config_memsize(adev);
1025
1026         if ((reg != 0) && (reg != 0xffffffff))
1027                 return false;
1028
1029         return true;
1030 }
1031
1032 /* if we get transitioned to only one device, take VGA back */
1033 /**
1034  * amdgpu_device_vga_set_decode - enable/disable vga decode
1035  *
1036  * @cookie: amdgpu_device pointer
1037  * @state: enable/disable vga decode
1038  *
1039  * Enable/disable vga decode (all asics).
1040  * Returns VGA resource flags.
1041  */
1042 static unsigned int amdgpu_device_vga_set_decode(void *cookie, bool state)
1043 {
1044         struct amdgpu_device *adev = cookie;
1045         amdgpu_asic_set_vga_state(adev, state);
1046         if (state)
1047                 return VGA_RSRC_LEGACY_IO | VGA_RSRC_LEGACY_MEM |
1048                        VGA_RSRC_NORMAL_IO | VGA_RSRC_NORMAL_MEM;
1049         else
1050                 return VGA_RSRC_NORMAL_IO | VGA_RSRC_NORMAL_MEM;
1051 }
1052
1053 /**
1054  * amdgpu_device_check_block_size - validate the vm block size
1055  *
1056  * @adev: amdgpu_device pointer
1057  *
1058  * Validates the vm block size specified via module parameter.
1059  * The vm block size defines number of bits in page table versus page directory,
1060  * a page is 4KB so we have 12 bits offset, minimum 9 bits in the
1061  * page table and the remaining bits are in the page directory.
1062  */
1063 static void amdgpu_device_check_block_size(struct amdgpu_device *adev)
1064 {
1065         /* defines number of bits in page table versus page directory,
1066          * a page is 4KB so we have 12 bits offset, minimum 9 bits in the
1067          * page table and the remaining bits are in the page directory */
1068         if (amdgpu_vm_block_size == -1)
1069                 return;
1070
1071         if (amdgpu_vm_block_size < 9) {
1072                 dev_warn(adev->dev, "VM page table size (%d) too small\n",
1073                          amdgpu_vm_block_size);
1074                 amdgpu_vm_block_size = -1;
1075         }
1076 }
1077
1078 /**
1079  * amdgpu_device_check_vm_size - validate the vm size
1080  *
1081  * @adev: amdgpu_device pointer
1082  *
1083  * Validates the vm size in GB specified via module parameter.
1084  * The VM size is the size of the GPU virtual memory space in GB.
1085  */
1086 static void amdgpu_device_check_vm_size(struct amdgpu_device *adev)
1087 {
1088         /* no need to check the default value */
1089         if (amdgpu_vm_size == -1)
1090                 return;
1091
1092         if (amdgpu_vm_size < 1) {
1093                 dev_warn(adev->dev, "VM size (%d) too small, min is 1GB\n",
1094                          amdgpu_vm_size);
1095                 amdgpu_vm_size = -1;
1096         }
1097 }
1098
1099 static void amdgpu_device_check_smu_prv_buffer_size(struct amdgpu_device *adev)
1100 {
1101         struct sysinfo si;
1102         bool is_os_64 = (sizeof(void *) == 8);
1103         uint64_t total_memory;
1104         uint64_t dram_size_seven_GB = 0x1B8000000;
1105         uint64_t dram_size_three_GB = 0xB8000000;
1106
1107         if (amdgpu_smu_memory_pool_size == 0)
1108                 return;
1109
1110         if (!is_os_64) {
1111                 DRM_WARN("Not 64-bit OS, feature not supported\n");
1112                 goto def_value;
1113         }
1114         si_meminfo(&si);
1115         total_memory = (uint64_t)si.totalram * si.mem_unit;
1116
1117         if ((amdgpu_smu_memory_pool_size == 1) ||
1118                 (amdgpu_smu_memory_pool_size == 2)) {
1119                 if (total_memory < dram_size_three_GB)
1120                         goto def_value1;
1121         } else if ((amdgpu_smu_memory_pool_size == 4) ||
1122                 (amdgpu_smu_memory_pool_size == 8)) {
1123                 if (total_memory < dram_size_seven_GB)
1124                         goto def_value1;
1125         } else {
1126                 DRM_WARN("Smu memory pool size not supported\n");
1127                 goto def_value;
1128         }
1129         adev->pm.smu_prv_buffer_size = amdgpu_smu_memory_pool_size << 28;
1130
1131         return;
1132
1133 def_value1:
1134         DRM_WARN("No enough system memory\n");
1135 def_value:
1136         adev->pm.smu_prv_buffer_size = 0;
1137 }
1138
1139 /**
1140  * amdgpu_device_check_arguments - validate module params
1141  *
1142  * @adev: amdgpu_device pointer
1143  *
1144  * Validates certain module parameters and updates
1145  * the associated values used by the driver (all asics).
1146  */
1147 static int amdgpu_device_check_arguments(struct amdgpu_device *adev)
1148 {
1149         if (amdgpu_sched_jobs < 4) {
1150                 dev_warn(adev->dev, "sched jobs (%d) must be at least 4\n",
1151                          amdgpu_sched_jobs);
1152                 amdgpu_sched_jobs = 4;
1153         } else if (!is_power_of_2(amdgpu_sched_jobs)){
1154                 dev_warn(adev->dev, "sched jobs (%d) must be a power of 2\n",
1155                          amdgpu_sched_jobs);
1156                 amdgpu_sched_jobs = roundup_pow_of_two(amdgpu_sched_jobs);
1157         }
1158
1159         if (amdgpu_gart_size != -1 && amdgpu_gart_size < 32) {
1160                 /* gart size must be greater or equal to 32M */
1161                 dev_warn(adev->dev, "gart size (%d) too small\n",
1162                          amdgpu_gart_size);
1163                 amdgpu_gart_size = -1;
1164         }
1165
1166         if (amdgpu_gtt_size != -1 && amdgpu_gtt_size < 32) {
1167                 /* gtt size must be greater or equal to 32M */
1168                 dev_warn(adev->dev, "gtt size (%d) too small\n",
1169                                  amdgpu_gtt_size);
1170                 amdgpu_gtt_size = -1;
1171         }
1172
1173         /* valid range is between 4 and 9 inclusive */
1174         if (amdgpu_vm_fragment_size != -1 &&
1175             (amdgpu_vm_fragment_size > 9 || amdgpu_vm_fragment_size < 4)) {
1176                 dev_warn(adev->dev, "valid range is between 4 and 9\n");
1177                 amdgpu_vm_fragment_size = -1;
1178         }
1179
1180         if (amdgpu_sched_hw_submission < 2) {
1181                 dev_warn(adev->dev, "sched hw submission jobs (%d) must be at least 2\n",
1182                          amdgpu_sched_hw_submission);
1183                 amdgpu_sched_hw_submission = 2;
1184         } else if (!is_power_of_2(amdgpu_sched_hw_submission)) {
1185                 dev_warn(adev->dev, "sched hw submission jobs (%d) must be a power of 2\n",
1186                          amdgpu_sched_hw_submission);
1187                 amdgpu_sched_hw_submission = roundup_pow_of_two(amdgpu_sched_hw_submission);
1188         }
1189
1190         amdgpu_device_check_smu_prv_buffer_size(adev);
1191
1192         amdgpu_device_check_vm_size(adev);
1193
1194         amdgpu_device_check_block_size(adev);
1195
1196         adev->firmware.load_type = amdgpu_ucode_get_load_type(adev, amdgpu_fw_load_type);
1197
1198         amdgpu_gmc_tmz_set(adev);
1199
1200         return 0;
1201 }
1202
1203 /**
1204  * amdgpu_switcheroo_set_state - set switcheroo state
1205  *
1206  * @pdev: pci dev pointer
1207  * @state: vga_switcheroo state
1208  *
1209  * Callback for the switcheroo driver.  Suspends or resumes the
1210  * the asics before or after it is powered up using ACPI methods.
1211  */
1212 static void amdgpu_switcheroo_set_state(struct pci_dev *pdev, enum vga_switcheroo_state state)
1213 {
1214         struct drm_device *dev = pci_get_drvdata(pdev);
1215         int r;
1216
1217         if (amdgpu_device_supports_boco(dev) && state == VGA_SWITCHEROO_OFF)
1218                 return;
1219
1220         if (state == VGA_SWITCHEROO_ON) {
1221                 pr_info("switched on\n");
1222                 /* don't suspend or resume card normally */
1223                 dev->switch_power_state = DRM_SWITCH_POWER_CHANGING;
1224
1225                 pci_set_power_state(dev->pdev, PCI_D0);
1226                 pci_restore_state(dev->pdev);
1227                 r = pci_enable_device(dev->pdev);
1228                 if (r)
1229                         DRM_WARN("pci_enable_device failed (%d)\n", r);
1230                 amdgpu_device_resume(dev, true);
1231
1232                 dev->switch_power_state = DRM_SWITCH_POWER_ON;
1233                 drm_kms_helper_poll_enable(dev);
1234         } else {
1235                 pr_info("switched off\n");
1236                 drm_kms_helper_poll_disable(dev);
1237                 dev->switch_power_state = DRM_SWITCH_POWER_CHANGING;
1238                 amdgpu_device_suspend(dev, true);
1239                 pci_save_state(dev->pdev);
1240                 /* Shut down the device */
1241                 pci_disable_device(dev->pdev);
1242                 pci_set_power_state(dev->pdev, PCI_D3cold);
1243                 dev->switch_power_state = DRM_SWITCH_POWER_OFF;
1244         }
1245 }
1246
1247 /**
1248  * amdgpu_switcheroo_can_switch - see if switcheroo state can change
1249  *
1250  * @pdev: pci dev pointer
1251  *
1252  * Callback for the switcheroo driver.  Check of the switcheroo
1253  * state can be changed.
1254  * Returns true if the state can be changed, false if not.
1255  */
1256 static bool amdgpu_switcheroo_can_switch(struct pci_dev *pdev)
1257 {
1258         struct drm_device *dev = pci_get_drvdata(pdev);
1259
1260         /*
1261         * FIXME: open_count is protected by drm_global_mutex but that would lead to
1262         * locking inversion with the driver load path. And the access here is
1263         * completely racy anyway. So don't bother with locking for now.
1264         */
1265         return atomic_read(&dev->open_count) == 0;
1266 }
1267
1268 static const struct vga_switcheroo_client_ops amdgpu_switcheroo_ops = {
1269         .set_gpu_state = amdgpu_switcheroo_set_state,
1270         .reprobe = NULL,
1271         .can_switch = amdgpu_switcheroo_can_switch,
1272 };
1273
1274 /**
1275  * amdgpu_device_ip_set_clockgating_state - set the CG state
1276  *
1277  * @dev: amdgpu_device pointer
1278  * @block_type: Type of hardware IP (SMU, GFX, UVD, etc.)
1279  * @state: clockgating state (gate or ungate)
1280  *
1281  * Sets the requested clockgating state for all instances of
1282  * the hardware IP specified.
1283  * Returns the error code from the last instance.
1284  */
1285 int amdgpu_device_ip_set_clockgating_state(void *dev,
1286                                            enum amd_ip_block_type block_type,
1287                                            enum amd_clockgating_state state)
1288 {
1289         struct amdgpu_device *adev = dev;
1290         int i, r = 0;
1291
1292         for (i = 0; i < adev->num_ip_blocks; i++) {
1293                 if (!adev->ip_blocks[i].status.valid)
1294                         continue;
1295                 if (adev->ip_blocks[i].version->type != block_type)
1296                         continue;
1297                 if (!adev->ip_blocks[i].version->funcs->set_clockgating_state)
1298                         continue;
1299                 r = adev->ip_blocks[i].version->funcs->set_clockgating_state(
1300                         (void *)adev, state);
1301                 if (r)
1302                         DRM_ERROR("set_clockgating_state of IP block <%s> failed %d\n",
1303                                   adev->ip_blocks[i].version->funcs->name, r);
1304         }
1305         return r;
1306 }
1307
1308 /**
1309  * amdgpu_device_ip_set_powergating_state - set the PG state
1310  *
1311  * @dev: amdgpu_device pointer
1312  * @block_type: Type of hardware IP (SMU, GFX, UVD, etc.)
1313  * @state: powergating state (gate or ungate)
1314  *
1315  * Sets the requested powergating state for all instances of
1316  * the hardware IP specified.
1317  * Returns the error code from the last instance.
1318  */
1319 int amdgpu_device_ip_set_powergating_state(void *dev,
1320                                            enum amd_ip_block_type block_type,
1321                                            enum amd_powergating_state state)
1322 {
1323         struct amdgpu_device *adev = dev;
1324         int i, r = 0;
1325
1326         for (i = 0; i < adev->num_ip_blocks; i++) {
1327                 if (!adev->ip_blocks[i].status.valid)
1328                         continue;
1329                 if (adev->ip_blocks[i].version->type != block_type)
1330                         continue;
1331                 if (!adev->ip_blocks[i].version->funcs->set_powergating_state)
1332                         continue;
1333                 r = adev->ip_blocks[i].version->funcs->set_powergating_state(
1334                         (void *)adev, state);
1335                 if (r)
1336                         DRM_ERROR("set_powergating_state of IP block <%s> failed %d\n",
1337                                   adev->ip_blocks[i].version->funcs->name, r);
1338         }
1339         return r;
1340 }
1341
1342 /**
1343  * amdgpu_device_ip_get_clockgating_state - get the CG state
1344  *
1345  * @adev: amdgpu_device pointer
1346  * @flags: clockgating feature flags
1347  *
1348  * Walks the list of IPs on the device and updates the clockgating
1349  * flags for each IP.
1350  * Updates @flags with the feature flags for each hardware IP where
1351  * clockgating is enabled.
1352  */
1353 void amdgpu_device_ip_get_clockgating_state(struct amdgpu_device *adev,
1354                                             u32 *flags)
1355 {
1356         int i;
1357
1358         for (i = 0; i < adev->num_ip_blocks; i++) {
1359                 if (!adev->ip_blocks[i].status.valid)
1360                         continue;
1361                 if (adev->ip_blocks[i].version->funcs->get_clockgating_state)
1362                         adev->ip_blocks[i].version->funcs->get_clockgating_state((void *)adev, flags);
1363         }
1364 }
1365
1366 /**
1367  * amdgpu_device_ip_wait_for_idle - wait for idle
1368  *
1369  * @adev: amdgpu_device pointer
1370  * @block_type: Type of hardware IP (SMU, GFX, UVD, etc.)
1371  *
1372  * Waits for the request hardware IP to be idle.
1373  * Returns 0 for success or a negative error code on failure.
1374  */
1375 int amdgpu_device_ip_wait_for_idle(struct amdgpu_device *adev,
1376                                    enum amd_ip_block_type block_type)
1377 {
1378         int i, r;
1379
1380         for (i = 0; i < adev->num_ip_blocks; i++) {
1381                 if (!adev->ip_blocks[i].status.valid)
1382                         continue;
1383                 if (adev->ip_blocks[i].version->type == block_type) {
1384                         r = adev->ip_blocks[i].version->funcs->wait_for_idle((void *)adev);
1385                         if (r)
1386                                 return r;
1387                         break;
1388                 }
1389         }
1390         return 0;
1391
1392 }
1393
1394 /**
1395  * amdgpu_device_ip_is_idle - is the hardware IP idle
1396  *
1397  * @adev: amdgpu_device pointer
1398  * @block_type: Type of hardware IP (SMU, GFX, UVD, etc.)
1399  *
1400  * Check if the hardware IP is idle or not.
1401  * Returns true if it the IP is idle, false if not.
1402  */
1403 bool amdgpu_device_ip_is_idle(struct amdgpu_device *adev,
1404                               enum amd_ip_block_type block_type)
1405 {
1406         int i;
1407
1408         for (i = 0; i < adev->num_ip_blocks; i++) {
1409                 if (!adev->ip_blocks[i].status.valid)
1410                         continue;
1411                 if (adev->ip_blocks[i].version->type == block_type)
1412                         return adev->ip_blocks[i].version->funcs->is_idle((void *)adev);
1413         }
1414         return true;
1415
1416 }
1417
1418 /**
1419  * amdgpu_device_ip_get_ip_block - get a hw IP pointer
1420  *
1421  * @adev: amdgpu_device pointer
1422  * @type: Type of hardware IP (SMU, GFX, UVD, etc.)
1423  *
1424  * Returns a pointer to the hardware IP block structure
1425  * if it exists for the asic, otherwise NULL.
1426  */
1427 struct amdgpu_ip_block *
1428 amdgpu_device_ip_get_ip_block(struct amdgpu_device *adev,
1429                               enum amd_ip_block_type type)
1430 {
1431         int i;
1432
1433         for (i = 0; i < adev->num_ip_blocks; i++)
1434                 if (adev->ip_blocks[i].version->type == type)
1435                         return &adev->ip_blocks[i];
1436
1437         return NULL;
1438 }
1439
1440 /**
1441  * amdgpu_device_ip_block_version_cmp
1442  *
1443  * @adev: amdgpu_device pointer
1444  * @type: enum amd_ip_block_type
1445  * @major: major version
1446  * @minor: minor version
1447  *
1448  * return 0 if equal or greater
1449  * return 1 if smaller or the ip_block doesn't exist
1450  */
1451 int amdgpu_device_ip_block_version_cmp(struct amdgpu_device *adev,
1452                                        enum amd_ip_block_type type,
1453                                        u32 major, u32 minor)
1454 {
1455         struct amdgpu_ip_block *ip_block = amdgpu_device_ip_get_ip_block(adev, type);
1456
1457         if (ip_block && ((ip_block->version->major > major) ||
1458                         ((ip_block->version->major == major) &&
1459                         (ip_block->version->minor >= minor))))
1460                 return 0;
1461
1462         return 1;
1463 }
1464
1465 /**
1466  * amdgpu_device_ip_block_add
1467  *
1468  * @adev: amdgpu_device pointer
1469  * @ip_block_version: pointer to the IP to add
1470  *
1471  * Adds the IP block driver information to the collection of IPs
1472  * on the asic.
1473  */
1474 int amdgpu_device_ip_block_add(struct amdgpu_device *adev,
1475                                const struct amdgpu_ip_block_version *ip_block_version)
1476 {
1477         if (!ip_block_version)
1478                 return -EINVAL;
1479
1480         DRM_INFO("add ip block number %d <%s>\n", adev->num_ip_blocks,
1481                   ip_block_version->funcs->name);
1482
1483         adev->ip_blocks[adev->num_ip_blocks++].version = ip_block_version;
1484
1485         return 0;
1486 }
1487
1488 /**
1489  * amdgpu_device_enable_virtual_display - enable virtual display feature
1490  *
1491  * @adev: amdgpu_device pointer
1492  *
1493  * Enabled the virtual display feature if the user has enabled it via
1494  * the module parameter virtual_display.  This feature provides a virtual
1495  * display hardware on headless boards or in virtualized environments.
1496  * This function parses and validates the configuration string specified by
1497  * the user and configues the virtual display configuration (number of
1498  * virtual connectors, crtcs, etc.) specified.
1499  */
1500 static void amdgpu_device_enable_virtual_display(struct amdgpu_device *adev)
1501 {
1502         adev->enable_virtual_display = false;
1503
1504         if (amdgpu_virtual_display) {
1505                 struct drm_device *ddev = adev->ddev;
1506                 const char *pci_address_name = pci_name(ddev->pdev);
1507                 char *pciaddstr, *pciaddstr_tmp, *pciaddname_tmp, *pciaddname;
1508
1509                 pciaddstr = kstrdup(amdgpu_virtual_display, GFP_KERNEL);
1510                 pciaddstr_tmp = pciaddstr;
1511                 while ((pciaddname_tmp = strsep(&pciaddstr_tmp, ";"))) {
1512                         pciaddname = strsep(&pciaddname_tmp, ",");
1513                         if (!strcmp("all", pciaddname)
1514                             || !strcmp(pci_address_name, pciaddname)) {
1515                                 long num_crtc;
1516                                 int res = -1;
1517
1518                                 adev->enable_virtual_display = true;
1519
1520                                 if (pciaddname_tmp)
1521                                         res = kstrtol(pciaddname_tmp, 10,
1522                                                       &num_crtc);
1523
1524                                 if (!res) {
1525                                         if (num_crtc < 1)
1526                                                 num_crtc = 1;
1527                                         if (num_crtc > 6)
1528                                                 num_crtc = 6;
1529                                         adev->mode_info.num_crtc = num_crtc;
1530                                 } else {
1531                                         adev->mode_info.num_crtc = 1;
1532                                 }
1533                                 break;
1534                         }
1535                 }
1536
1537                 DRM_INFO("virtual display string:%s, %s:virtual_display:%d, num_crtc:%d\n",
1538                          amdgpu_virtual_display, pci_address_name,
1539                          adev->enable_virtual_display, adev->mode_info.num_crtc);
1540
1541                 kfree(pciaddstr);
1542         }
1543 }
1544
1545 /**
1546  * amdgpu_device_parse_gpu_info_fw - parse gpu info firmware
1547  *
1548  * @adev: amdgpu_device pointer
1549  *
1550  * Parses the asic configuration parameters specified in the gpu info
1551  * firmware and makes them availale to the driver for use in configuring
1552  * the asic.
1553  * Returns 0 on success, -EINVAL on failure.
1554  */
1555 static int amdgpu_device_parse_gpu_info_fw(struct amdgpu_device *adev)
1556 {
1557         const char *chip_name;
1558         char fw_name[40];
1559         int err;
1560         const struct gpu_info_firmware_header_v1_0 *hdr;
1561
1562         adev->firmware.gpu_info_fw = NULL;
1563
1564         if (adev->discovery_bin) {
1565                 amdgpu_discovery_get_gfx_info(adev);
1566
1567                 /*
1568                  * FIXME: The bounding box is still needed by Navi12, so
1569                  * temporarily read it from gpu_info firmware. Should be droped
1570                  * when DAL no longer needs it.
1571                  */
1572                 if (adev->asic_type != CHIP_NAVI12)
1573                         return 0;
1574         }
1575
1576         switch (adev->asic_type) {
1577 #ifdef CONFIG_DRM_AMDGPU_SI
1578         case CHIP_VERDE:
1579         case CHIP_TAHITI:
1580         case CHIP_PITCAIRN:
1581         case CHIP_OLAND:
1582         case CHIP_HAINAN:
1583 #endif
1584 #ifdef CONFIG_DRM_AMDGPU_CIK
1585         case CHIP_BONAIRE:
1586         case CHIP_HAWAII:
1587         case CHIP_KAVERI:
1588         case CHIP_KABINI:
1589         case CHIP_MULLINS:
1590 #endif
1591         case CHIP_TOPAZ:
1592         case CHIP_TONGA:
1593         case CHIP_FIJI:
1594         case CHIP_POLARIS10:
1595         case CHIP_POLARIS11:
1596         case CHIP_POLARIS12:
1597         case CHIP_VEGAM:
1598         case CHIP_CARRIZO:
1599         case CHIP_STONEY:
1600         case CHIP_VEGA20:
1601         default:
1602                 return 0;
1603         case CHIP_VEGA10:
1604                 chip_name = "vega10";
1605                 break;
1606         case CHIP_VEGA12:
1607                 chip_name = "vega12";
1608                 break;
1609         case CHIP_RAVEN:
1610                 if (adev->apu_flags & AMD_APU_IS_RAVEN2)
1611                         chip_name = "raven2";
1612                 else if (adev->apu_flags & AMD_APU_IS_PICASSO)
1613                         chip_name = "picasso";
1614                 else
1615                         chip_name = "raven";
1616                 break;
1617         case CHIP_ARCTURUS:
1618                 chip_name = "arcturus";
1619                 break;
1620         case CHIP_RENOIR:
1621                 chip_name = "renoir";
1622                 break;
1623         case CHIP_NAVI10:
1624                 chip_name = "navi10";
1625                 break;
1626         case CHIP_NAVI14:
1627                 chip_name = "navi14";
1628                 break;
1629         case CHIP_NAVI12:
1630                 chip_name = "navi12";
1631                 break;
1632         case CHIP_SIENNA_CICHLID:
1633                 chip_name = "sienna_cichlid";
1634                 break;
1635         }
1636
1637         snprintf(fw_name, sizeof(fw_name), "amdgpu/%s_gpu_info.bin", chip_name);
1638         err = request_firmware(&adev->firmware.gpu_info_fw, fw_name, adev->dev);
1639         if (err) {
1640                 dev_err(adev->dev,
1641                         "Failed to load gpu_info firmware \"%s\"\n",
1642                         fw_name);
1643                 goto out;
1644         }
1645         err = amdgpu_ucode_validate(adev->firmware.gpu_info_fw);
1646         if (err) {
1647                 dev_err(adev->dev,
1648                         "Failed to validate gpu_info firmware \"%s\"\n",
1649                         fw_name);
1650                 goto out;
1651         }
1652
1653         hdr = (const struct gpu_info_firmware_header_v1_0 *)adev->firmware.gpu_info_fw->data;
1654         amdgpu_ucode_print_gpu_info_hdr(&hdr->header);
1655
1656         switch (hdr->version_major) {
1657         case 1:
1658         {
1659                 const struct gpu_info_firmware_v1_0 *gpu_info_fw =
1660                         (const struct gpu_info_firmware_v1_0 *)(adev->firmware.gpu_info_fw->data +
1661                                                                 le32_to_cpu(hdr->header.ucode_array_offset_bytes));
1662
1663                 /*
1664                  * Should be droped when DAL no longer needs it.
1665                  */
1666                 if (adev->asic_type == CHIP_NAVI12)
1667                         goto parse_soc_bounding_box;
1668
1669                 adev->gfx.config.max_shader_engines = le32_to_cpu(gpu_info_fw->gc_num_se);
1670                 adev->gfx.config.max_cu_per_sh = le32_to_cpu(gpu_info_fw->gc_num_cu_per_sh);
1671                 adev->gfx.config.max_sh_per_se = le32_to_cpu(gpu_info_fw->gc_num_sh_per_se);
1672                 adev->gfx.config.max_backends_per_se = le32_to_cpu(gpu_info_fw->gc_num_rb_per_se);
1673                 adev->gfx.config.max_texture_channel_caches =
1674                         le32_to_cpu(gpu_info_fw->gc_num_tccs);
1675                 adev->gfx.config.max_gprs = le32_to_cpu(gpu_info_fw->gc_num_gprs);
1676                 adev->gfx.config.max_gs_threads = le32_to_cpu(gpu_info_fw->gc_num_max_gs_thds);
1677                 adev->gfx.config.gs_vgt_table_depth = le32_to_cpu(gpu_info_fw->gc_gs_table_depth);
1678                 adev->gfx.config.gs_prim_buffer_depth = le32_to_cpu(gpu_info_fw->gc_gsprim_buff_depth);
1679                 adev->gfx.config.double_offchip_lds_buf =
1680                         le32_to_cpu(gpu_info_fw->gc_double_offchip_lds_buffer);
1681                 adev->gfx.cu_info.wave_front_size = le32_to_cpu(gpu_info_fw->gc_wave_size);
1682                 adev->gfx.cu_info.max_waves_per_simd =
1683                         le32_to_cpu(gpu_info_fw->gc_max_waves_per_simd);
1684                 adev->gfx.cu_info.max_scratch_slots_per_cu =
1685                         le32_to_cpu(gpu_info_fw->gc_max_scratch_slots_per_cu);
1686                 adev->gfx.cu_info.lds_size = le32_to_cpu(gpu_info_fw->gc_lds_size);
1687                 if (hdr->version_minor >= 1) {
1688                         const struct gpu_info_firmware_v1_1 *gpu_info_fw =
1689                                 (const struct gpu_info_firmware_v1_1 *)(adev->firmware.gpu_info_fw->data +
1690                                                                         le32_to_cpu(hdr->header.ucode_array_offset_bytes));
1691                         adev->gfx.config.num_sc_per_sh =
1692                                 le32_to_cpu(gpu_info_fw->num_sc_per_sh);
1693                         adev->gfx.config.num_packer_per_sc =
1694                                 le32_to_cpu(gpu_info_fw->num_packer_per_sc);
1695                 }
1696
1697 parse_soc_bounding_box:
1698                 /*
1699                  * soc bounding box info is not integrated in disocovery table,
1700                  * we always need to parse it from gpu info firmware if needed.
1701                  */
1702                 if (hdr->version_minor == 2) {
1703                         const struct gpu_info_firmware_v1_2 *gpu_info_fw =
1704                                 (const struct gpu_info_firmware_v1_2 *)(adev->firmware.gpu_info_fw->data +
1705                                                                         le32_to_cpu(hdr->header.ucode_array_offset_bytes));
1706                         adev->dm.soc_bounding_box = &gpu_info_fw->soc_bounding_box;
1707                 }
1708                 break;
1709         }
1710         default:
1711                 dev_err(adev->dev,
1712                         "Unsupported gpu_info table %d\n", hdr->header.ucode_version);
1713                 err = -EINVAL;
1714                 goto out;
1715         }
1716 out:
1717         return err;
1718 }
1719
1720 /**
1721  * amdgpu_device_ip_early_init - run early init for hardware IPs
1722  *
1723  * @adev: amdgpu_device pointer
1724  *
1725  * Early initialization pass for hardware IPs.  The hardware IPs that make
1726  * up each asic are discovered each IP's early_init callback is run.  This
1727  * is the first stage in initializing the asic.
1728  * Returns 0 on success, negative error code on failure.
1729  */
1730 static int amdgpu_device_ip_early_init(struct amdgpu_device *adev)
1731 {
1732         int i, r;
1733
1734         amdgpu_device_enable_virtual_display(adev);
1735
1736         if (amdgpu_sriov_vf(adev)) {
1737                 r = amdgpu_virt_request_full_gpu(adev, true);
1738                 if (r)
1739                         return r;
1740         }
1741
1742         switch (adev->asic_type) {
1743 #ifdef CONFIG_DRM_AMDGPU_SI
1744         case CHIP_VERDE:
1745         case CHIP_TAHITI:
1746         case CHIP_PITCAIRN:
1747         case CHIP_OLAND:
1748         case CHIP_HAINAN:
1749                 adev->family = AMDGPU_FAMILY_SI;
1750                 r = si_set_ip_blocks(adev);
1751                 if (r)
1752                         return r;
1753                 break;
1754 #endif
1755 #ifdef CONFIG_DRM_AMDGPU_CIK
1756         case CHIP_BONAIRE:
1757         case CHIP_HAWAII:
1758         case CHIP_KAVERI:
1759         case CHIP_KABINI:
1760         case CHIP_MULLINS:
1761                 if (adev->flags & AMD_IS_APU)
1762                         adev->family = AMDGPU_FAMILY_KV;
1763                 else
1764                         adev->family = AMDGPU_FAMILY_CI;
1765
1766                 r = cik_set_ip_blocks(adev);
1767                 if (r)
1768                         return r;
1769                 break;
1770 #endif
1771         case CHIP_TOPAZ:
1772         case CHIP_TONGA:
1773         case CHIP_FIJI:
1774         case CHIP_POLARIS10:
1775         case CHIP_POLARIS11:
1776         case CHIP_POLARIS12:
1777         case CHIP_VEGAM:
1778         case CHIP_CARRIZO:
1779         case CHIP_STONEY:
1780                 if (adev->flags & AMD_IS_APU)
1781                         adev->family = AMDGPU_FAMILY_CZ;
1782                 else
1783                         adev->family = AMDGPU_FAMILY_VI;
1784
1785                 r = vi_set_ip_blocks(adev);
1786                 if (r)
1787                         return r;
1788                 break;
1789         case CHIP_VEGA10:
1790         case CHIP_VEGA12:
1791         case CHIP_VEGA20:
1792         case CHIP_RAVEN:
1793         case CHIP_ARCTURUS:
1794         case CHIP_RENOIR:
1795                 if (adev->flags & AMD_IS_APU)
1796                         adev->family = AMDGPU_FAMILY_RV;
1797                 else
1798                         adev->family = AMDGPU_FAMILY_AI;
1799
1800                 r = soc15_set_ip_blocks(adev);
1801                 if (r)
1802                         return r;
1803                 break;
1804         case  CHIP_NAVI10:
1805         case  CHIP_NAVI14:
1806         case  CHIP_NAVI12:
1807         case  CHIP_SIENNA_CICHLID:
1808                 adev->family = AMDGPU_FAMILY_NV;
1809
1810                 r = nv_set_ip_blocks(adev);
1811                 if (r)
1812                         return r;
1813                 break;
1814         default:
1815                 /* FIXME: not supported yet */
1816                 return -EINVAL;
1817         }
1818
1819         amdgpu_amdkfd_device_probe(adev);
1820
1821         adev->pm.pp_feature = amdgpu_pp_feature_mask;
1822         if (amdgpu_sriov_vf(adev) || sched_policy == KFD_SCHED_POLICY_NO_HWS)
1823                 adev->pm.pp_feature &= ~PP_GFXOFF_MASK;
1824
1825         for (i = 0; i < adev->num_ip_blocks; i++) {
1826                 if ((amdgpu_ip_block_mask & (1 << i)) == 0) {
1827                         DRM_ERROR("disabled ip block: %d <%s>\n",
1828                                   i, adev->ip_blocks[i].version->funcs->name);
1829                         adev->ip_blocks[i].status.valid = false;
1830                 } else {
1831                         if (adev->ip_blocks[i].version->funcs->early_init) {
1832                                 r = adev->ip_blocks[i].version->funcs->early_init((void *)adev);
1833                                 if (r == -ENOENT) {
1834                                         adev->ip_blocks[i].status.valid = false;
1835                                 } else if (r) {
1836                                         DRM_ERROR("early_init of IP block <%s> failed %d\n",
1837                                                   adev->ip_blocks[i].version->funcs->name, r);
1838                                         return r;
1839                                 } else {
1840                                         adev->ip_blocks[i].status.valid = true;
1841                                 }
1842                         } else {
1843                                 adev->ip_blocks[i].status.valid = true;
1844                         }
1845                 }
1846                 /* get the vbios after the asic_funcs are set up */
1847                 if (adev->ip_blocks[i].version->type == AMD_IP_BLOCK_TYPE_COMMON) {
1848                         r = amdgpu_device_parse_gpu_info_fw(adev);
1849                         if (r)
1850                                 return r;
1851
1852                         /* Read BIOS */
1853                         if (!amdgpu_get_bios(adev))
1854                                 return -EINVAL;
1855
1856                         r = amdgpu_atombios_init(adev);
1857                         if (r) {
1858                                 dev_err(adev->dev, "amdgpu_atombios_init failed\n");
1859                                 amdgpu_vf_error_put(adev, AMDGIM_ERROR_VF_ATOMBIOS_INIT_FAIL, 0, 0);
1860                                 return r;
1861                         }
1862                 }
1863         }
1864
1865         adev->cg_flags &= amdgpu_cg_mask;
1866         adev->pg_flags &= amdgpu_pg_mask;
1867
1868         return 0;
1869 }
1870
1871 static int amdgpu_device_ip_hw_init_phase1(struct amdgpu_device *adev)
1872 {
1873         int i, r;
1874
1875         for (i = 0; i < adev->num_ip_blocks; i++) {
1876                 if (!adev->ip_blocks[i].status.sw)
1877                         continue;
1878                 if (adev->ip_blocks[i].status.hw)
1879                         continue;
1880                 if (adev->ip_blocks[i].version->type == AMD_IP_BLOCK_TYPE_COMMON ||
1881                     (amdgpu_sriov_vf(adev) && (adev->ip_blocks[i].version->type == AMD_IP_BLOCK_TYPE_PSP)) ||
1882                     adev->ip_blocks[i].version->type == AMD_IP_BLOCK_TYPE_IH) {
1883                         r = adev->ip_blocks[i].version->funcs->hw_init(adev);
1884                         if (r) {
1885                                 DRM_ERROR("hw_init of IP block <%s> failed %d\n",
1886                                           adev->ip_blocks[i].version->funcs->name, r);
1887                                 return r;
1888                         }
1889                         adev->ip_blocks[i].status.hw = true;
1890                 }
1891         }
1892
1893         return 0;
1894 }
1895
1896 static int amdgpu_device_ip_hw_init_phase2(struct amdgpu_device *adev)
1897 {
1898         int i, r;
1899
1900         for (i = 0; i < adev->num_ip_blocks; i++) {
1901                 if (!adev->ip_blocks[i].status.sw)
1902                         continue;
1903                 if (adev->ip_blocks[i].status.hw)
1904                         continue;
1905                 r = adev->ip_blocks[i].version->funcs->hw_init(adev);
1906                 if (r) {
1907                         DRM_ERROR("hw_init of IP block <%s> failed %d\n",
1908                                   adev->ip_blocks[i].version->funcs->name, r);
1909                         return r;
1910                 }
1911                 adev->ip_blocks[i].status.hw = true;
1912         }
1913
1914         return 0;
1915 }
1916
1917 static int amdgpu_device_fw_loading(struct amdgpu_device *adev)
1918 {
1919         int r = 0;
1920         int i;
1921         uint32_t smu_version;
1922
1923         if (adev->asic_type >= CHIP_VEGA10) {
1924                 for (i = 0; i < adev->num_ip_blocks; i++) {
1925                         if (adev->ip_blocks[i].version->type != AMD_IP_BLOCK_TYPE_PSP)
1926                                 continue;
1927
1928                         /* no need to do the fw loading again if already done*/
1929                         if (adev->ip_blocks[i].status.hw == true)
1930                                 break;
1931
1932                         if (adev->in_gpu_reset || adev->in_suspend) {
1933                                 r = adev->ip_blocks[i].version->funcs->resume(adev);
1934                                 if (r) {
1935                                         DRM_ERROR("resume of IP block <%s> failed %d\n",
1936                                                           adev->ip_blocks[i].version->funcs->name, r);
1937                                         return r;
1938                                 }
1939                         } else {
1940                                 r = adev->ip_blocks[i].version->funcs->hw_init(adev);
1941                                 if (r) {
1942                                         DRM_ERROR("hw_init of IP block <%s> failed %d\n",
1943                                                           adev->ip_blocks[i].version->funcs->name, r);
1944                                         return r;
1945                                 }
1946                         }
1947
1948                         adev->ip_blocks[i].status.hw = true;
1949                         break;
1950                 }
1951         }
1952
1953         if (!amdgpu_sriov_vf(adev) || adev->asic_type == CHIP_TONGA)
1954                 r = amdgpu_pm_load_smu_firmware(adev, &smu_version);
1955
1956         return r;
1957 }
1958
1959 /**
1960  * amdgpu_device_ip_init - run init for hardware IPs
1961  *
1962  * @adev: amdgpu_device pointer
1963  *
1964  * Main initialization pass for hardware IPs.  The list of all the hardware
1965  * IPs that make up the asic is walked and the sw_init and hw_init callbacks
1966  * are run.  sw_init initializes the software state associated with each IP
1967  * and hw_init initializes the hardware associated with each IP.
1968  * Returns 0 on success, negative error code on failure.
1969  */
1970 static int amdgpu_device_ip_init(struct amdgpu_device *adev)
1971 {
1972         int i, r;
1973
1974         r = amdgpu_ras_init(adev);
1975         if (r)
1976                 return r;
1977
1978         for (i = 0; i < adev->num_ip_blocks; i++) {
1979                 if (!adev->ip_blocks[i].status.valid)
1980                         continue;
1981                 r = adev->ip_blocks[i].version->funcs->sw_init((void *)adev);
1982                 if (r) {
1983                         DRM_ERROR("sw_init of IP block <%s> failed %d\n",
1984                                   adev->ip_blocks[i].version->funcs->name, r);
1985                         goto init_failed;
1986                 }
1987                 adev->ip_blocks[i].status.sw = true;
1988
1989                 /* need to do gmc hw init early so we can allocate gpu mem */
1990                 if (adev->ip_blocks[i].version->type == AMD_IP_BLOCK_TYPE_GMC) {
1991                         r = amdgpu_device_vram_scratch_init(adev);
1992                         if (r) {
1993                                 DRM_ERROR("amdgpu_vram_scratch_init failed %d\n", r);
1994                                 goto init_failed;
1995                         }
1996                         r = adev->ip_blocks[i].version->funcs->hw_init((void *)adev);
1997                         if (r) {
1998                                 DRM_ERROR("hw_init %d failed %d\n", i, r);
1999                                 goto init_failed;
2000                         }
2001                         r = amdgpu_device_wb_init(adev);
2002                         if (r) {
2003                                 DRM_ERROR("amdgpu_device_wb_init failed %d\n", r);
2004                                 goto init_failed;
2005                         }
2006                         adev->ip_blocks[i].status.hw = true;
2007
2008                         /* right after GMC hw init, we create CSA */
2009                         if (amdgpu_mcbp || amdgpu_sriov_vf(adev)) {
2010                                 r = amdgpu_allocate_static_csa(adev, &adev->virt.csa_obj,
2011                                                                 AMDGPU_GEM_DOMAIN_VRAM,
2012                                                                 AMDGPU_CSA_SIZE);
2013                                 if (r) {
2014                                         DRM_ERROR("allocate CSA failed %d\n", r);
2015                                         goto init_failed;
2016                                 }
2017                         }
2018                 }
2019         }
2020
2021         if (amdgpu_sriov_vf(adev))
2022                 amdgpu_virt_init_data_exchange(adev);
2023
2024         r = amdgpu_ib_pool_init(adev);
2025         if (r) {
2026                 dev_err(adev->dev, "IB initialization failed (%d).\n", r);
2027                 amdgpu_vf_error_put(adev, AMDGIM_ERROR_VF_IB_INIT_FAIL, 0, r);
2028                 goto init_failed;
2029         }
2030
2031         r = amdgpu_ucode_create_bo(adev); /* create ucode bo when sw_init complete*/
2032         if (r)
2033                 goto init_failed;
2034
2035         r = amdgpu_device_ip_hw_init_phase1(adev);
2036         if (r)
2037                 goto init_failed;
2038
2039         r = amdgpu_device_fw_loading(adev);
2040         if (r)
2041                 goto init_failed;
2042
2043         r = amdgpu_device_ip_hw_init_phase2(adev);
2044         if (r)
2045                 goto init_failed;
2046
2047         /*
2048          * retired pages will be loaded from eeprom and reserved here,
2049          * it should be called after amdgpu_device_ip_hw_init_phase2  since
2050          * for some ASICs the RAS EEPROM code relies on SMU fully functioning
2051          * for I2C communication which only true at this point.
2052          * recovery_init may fail, but it can free all resources allocated by
2053          * itself and its failure should not stop amdgpu init process.
2054          *
2055          * Note: theoretically, this should be called before all vram allocations
2056          * to protect retired page from abusing
2057          */
2058         amdgpu_ras_recovery_init(adev);
2059
2060         if (adev->gmc.xgmi.num_physical_nodes > 1)
2061                 amdgpu_xgmi_add_device(adev);
2062         amdgpu_amdkfd_device_init(adev);
2063
2064         amdgpu_fru_get_product_info(adev);
2065
2066 init_failed:
2067         if (amdgpu_sriov_vf(adev))
2068                 amdgpu_virt_release_full_gpu(adev, true);
2069
2070         return r;
2071 }
2072
2073 /**
2074  * amdgpu_device_fill_reset_magic - writes reset magic to gart pointer
2075  *
2076  * @adev: amdgpu_device pointer
2077  *
2078  * Writes a reset magic value to the gart pointer in VRAM.  The driver calls
2079  * this function before a GPU reset.  If the value is retained after a
2080  * GPU reset, VRAM has not been lost.  Some GPU resets may destry VRAM contents.
2081  */
2082 static void amdgpu_device_fill_reset_magic(struct amdgpu_device *adev)
2083 {
2084         memcpy(adev->reset_magic, adev->gart.ptr, AMDGPU_RESET_MAGIC_NUM);
2085 }
2086
2087 /**
2088  * amdgpu_device_check_vram_lost - check if vram is valid
2089  *
2090  * @adev: amdgpu_device pointer
2091  *
2092  * Checks the reset magic value written to the gart pointer in VRAM.
2093  * The driver calls this after a GPU reset to see if the contents of
2094  * VRAM is lost or now.
2095  * returns true if vram is lost, false if not.
2096  */
2097 static bool amdgpu_device_check_vram_lost(struct amdgpu_device *adev)
2098 {
2099         if (memcmp(adev->gart.ptr, adev->reset_magic,
2100                         AMDGPU_RESET_MAGIC_NUM))
2101                 return true;
2102
2103         if (!adev->in_gpu_reset)
2104                 return false;
2105
2106         /*
2107          * For all ASICs with baco/mode1 reset, the VRAM is
2108          * always assumed to be lost.
2109          */
2110         switch (amdgpu_asic_reset_method(adev)) {
2111         case AMD_RESET_METHOD_BACO:
2112         case AMD_RESET_METHOD_MODE1:
2113                 return true;
2114         default:
2115                 return false;
2116         }
2117 }
2118
2119 /**
2120  * amdgpu_device_set_cg_state - set clockgating for amdgpu device
2121  *
2122  * @adev: amdgpu_device pointer
2123  * @state: clockgating state (gate or ungate)
2124  *
2125  * The list of all the hardware IPs that make up the asic is walked and the
2126  * set_clockgating_state callbacks are run.
2127  * Late initialization pass enabling clockgating for hardware IPs.
2128  * Fini or suspend, pass disabling clockgating for hardware IPs.
2129  * Returns 0 on success, negative error code on failure.
2130  */
2131
2132 static int amdgpu_device_set_cg_state(struct amdgpu_device *adev,
2133                                                 enum amd_clockgating_state state)
2134 {
2135         int i, j, r;
2136
2137         if (amdgpu_emu_mode == 1)
2138                 return 0;
2139
2140         for (j = 0; j < adev->num_ip_blocks; j++) {
2141                 i = state == AMD_CG_STATE_GATE ? j : adev->num_ip_blocks - j - 1;
2142                 if (!adev->ip_blocks[i].status.late_initialized)
2143                         continue;
2144                 /* skip CG for VCE/UVD, it's handled specially */
2145                 if (adev->ip_blocks[i].version->type != AMD_IP_BLOCK_TYPE_UVD &&
2146                     adev->ip_blocks[i].version->type != AMD_IP_BLOCK_TYPE_VCE &&
2147                     adev->ip_blocks[i].version->type != AMD_IP_BLOCK_TYPE_VCN &&
2148                     adev->ip_blocks[i].version->type != AMD_IP_BLOCK_TYPE_JPEG &&
2149                     adev->ip_blocks[i].version->funcs->set_clockgating_state) {
2150                         /* enable clockgating to save power */
2151                         r = adev->ip_blocks[i].version->funcs->set_clockgating_state((void *)adev,
2152                                                                                      state);
2153                         if (r) {
2154                                 DRM_ERROR("set_clockgating_state(gate) of IP block <%s> failed %d\n",
2155                                           adev->ip_blocks[i].version->funcs->name, r);
2156                                 return r;
2157                         }
2158                 }
2159         }
2160
2161         return 0;
2162 }
2163
2164 static int amdgpu_device_set_pg_state(struct amdgpu_device *adev, enum amd_powergating_state state)
2165 {
2166         int i, j, r;
2167
2168         if (amdgpu_emu_mode == 1)
2169                 return 0;
2170
2171         for (j = 0; j < adev->num_ip_blocks; j++) {
2172                 i = state == AMD_PG_STATE_GATE ? j : adev->num_ip_blocks - j - 1;
2173                 if (!adev->ip_blocks[i].status.late_initialized)
2174                         continue;
2175                 /* skip CG for VCE/UVD, it's handled specially */
2176                 if (adev->ip_blocks[i].version->type != AMD_IP_BLOCK_TYPE_UVD &&
2177                     adev->ip_blocks[i].version->type != AMD_IP_BLOCK_TYPE_VCE &&
2178                     adev->ip_blocks[i].version->type != AMD_IP_BLOCK_TYPE_VCN &&
2179                     adev->ip_blocks[i].version->type != AMD_IP_BLOCK_TYPE_JPEG &&
2180                     adev->ip_blocks[i].version->funcs->set_powergating_state) {
2181                         /* enable powergating to save power */
2182                         r = adev->ip_blocks[i].version->funcs->set_powergating_state((void *)adev,
2183                                                                                         state);
2184                         if (r) {
2185                                 DRM_ERROR("set_powergating_state(gate) of IP block <%s> failed %d\n",
2186                                           adev->ip_blocks[i].version->funcs->name, r);
2187                                 return r;
2188                         }
2189                 }
2190         }
2191         return 0;
2192 }
2193
2194 static int amdgpu_device_enable_mgpu_fan_boost(void)
2195 {
2196         struct amdgpu_gpu_instance *gpu_ins;
2197         struct amdgpu_device *adev;
2198         int i, ret = 0;
2199
2200         mutex_lock(&mgpu_info.mutex);
2201
2202         /*
2203          * MGPU fan boost feature should be enabled
2204          * only when there are two or more dGPUs in
2205          * the system
2206          */
2207         if (mgpu_info.num_dgpu < 2)
2208                 goto out;
2209
2210         for (i = 0; i < mgpu_info.num_dgpu; i++) {
2211                 gpu_ins = &(mgpu_info.gpu_ins[i]);
2212                 adev = gpu_ins->adev;
2213                 if (!(adev->flags & AMD_IS_APU) &&
2214                     !gpu_ins->mgpu_fan_enabled &&
2215                     adev->powerplay.pp_funcs &&
2216                     adev->powerplay.pp_funcs->enable_mgpu_fan_boost) {
2217                         ret = amdgpu_dpm_enable_mgpu_fan_boost(adev);
2218                         if (ret)
2219                                 break;
2220
2221                         gpu_ins->mgpu_fan_enabled = 1;
2222                 }
2223         }
2224
2225 out:
2226         mutex_unlock(&mgpu_info.mutex);
2227
2228         return ret;
2229 }
2230
2231 /**
2232  * amdgpu_device_ip_late_init - run late init for hardware IPs
2233  *
2234  * @adev: amdgpu_device pointer
2235  *
2236  * Late initialization pass for hardware IPs.  The list of all the hardware
2237  * IPs that make up the asic is walked and the late_init callbacks are run.
2238  * late_init covers any special initialization that an IP requires
2239  * after all of the have been initialized or something that needs to happen
2240  * late in the init process.
2241  * Returns 0 on success, negative error code on failure.
2242  */
2243 static int amdgpu_device_ip_late_init(struct amdgpu_device *adev)
2244 {
2245         struct amdgpu_gpu_instance *gpu_instance;
2246         int i = 0, r;
2247
2248         for (i = 0; i < adev->num_ip_blocks; i++) {
2249                 if (!adev->ip_blocks[i].status.hw)
2250                         continue;
2251                 if (adev->ip_blocks[i].version->funcs->late_init) {
2252                         r = adev->ip_blocks[i].version->funcs->late_init((void *)adev);
2253                         if (r) {
2254                                 DRM_ERROR("late_init of IP block <%s> failed %d\n",
2255                                           adev->ip_blocks[i].version->funcs->name, r);
2256                                 return r;
2257                         }
2258                 }
2259                 adev->ip_blocks[i].status.late_initialized = true;
2260         }
2261
2262         amdgpu_ras_set_error_query_ready(adev, true);
2263
2264         amdgpu_device_set_cg_state(adev, AMD_CG_STATE_GATE);
2265         amdgpu_device_set_pg_state(adev, AMD_PG_STATE_GATE);
2266
2267         amdgpu_device_fill_reset_magic(adev);
2268
2269         r = amdgpu_device_enable_mgpu_fan_boost();
2270         if (r)
2271                 DRM_ERROR("enable mgpu fan boost failed (%d).\n", r);
2272
2273
2274         if (adev->gmc.xgmi.num_physical_nodes > 1) {
2275                 mutex_lock(&mgpu_info.mutex);
2276
2277                 /*
2278                  * Reset device p-state to low as this was booted with high.
2279                  *
2280                  * This should be performed only after all devices from the same
2281                  * hive get initialized.
2282                  *
2283                  * However, it's unknown how many device in the hive in advance.
2284                  * As this is counted one by one during devices initializations.
2285                  *
2286                  * So, we wait for all XGMI interlinked devices initialized.
2287                  * This may bring some delays as those devices may come from
2288                  * different hives. But that should be OK.
2289                  */
2290                 if (mgpu_info.num_dgpu == adev->gmc.xgmi.num_physical_nodes) {
2291                         for (i = 0; i < mgpu_info.num_gpu; i++) {
2292                                 gpu_instance = &(mgpu_info.gpu_ins[i]);
2293                                 if (gpu_instance->adev->flags & AMD_IS_APU)
2294                                         continue;
2295
2296                                 r = amdgpu_xgmi_set_pstate(gpu_instance->adev,
2297                                                 AMDGPU_XGMI_PSTATE_MIN);
2298                                 if (r) {
2299                                         DRM_ERROR("pstate setting failed (%d).\n", r);
2300                                         break;
2301                                 }
2302                         }
2303                 }
2304
2305                 mutex_unlock(&mgpu_info.mutex);
2306         }
2307
2308         return 0;
2309 }
2310
2311 /**
2312  * amdgpu_device_ip_fini - run fini for hardware IPs
2313  *
2314  * @adev: amdgpu_device pointer
2315  *
2316  * Main teardown pass for hardware IPs.  The list of all the hardware
2317  * IPs that make up the asic is walked and the hw_fini and sw_fini callbacks
2318  * are run.  hw_fini tears down the hardware associated with each IP
2319  * and sw_fini tears down any software state associated with each IP.
2320  * Returns 0 on success, negative error code on failure.
2321  */
2322 static int amdgpu_device_ip_fini(struct amdgpu_device *adev)
2323 {
2324         int i, r;
2325
2326         if (amdgpu_sriov_vf(adev) && adev->virt.ras_init_done)
2327                 amdgpu_virt_release_ras_err_handler_data(adev);
2328
2329         amdgpu_ras_pre_fini(adev);
2330
2331         if (adev->gmc.xgmi.num_physical_nodes > 1)
2332                 amdgpu_xgmi_remove_device(adev);
2333
2334         amdgpu_amdkfd_device_fini(adev);
2335
2336         amdgpu_device_set_pg_state(adev, AMD_PG_STATE_UNGATE);
2337         amdgpu_device_set_cg_state(adev, AMD_CG_STATE_UNGATE);
2338
2339         /* need to disable SMC first */
2340         for (i = 0; i < adev->num_ip_blocks; i++) {
2341                 if (!adev->ip_blocks[i].status.hw)
2342                         continue;
2343                 if (adev->ip_blocks[i].version->type == AMD_IP_BLOCK_TYPE_SMC) {
2344                         r = adev->ip_blocks[i].version->funcs->hw_fini((void *)adev);
2345                         /* XXX handle errors */
2346                         if (r) {
2347                                 DRM_DEBUG("hw_fini of IP block <%s> failed %d\n",
2348                                           adev->ip_blocks[i].version->funcs->name, r);
2349                         }
2350                         adev->ip_blocks[i].status.hw = false;
2351                         break;
2352                 }
2353         }
2354
2355         for (i = adev->num_ip_blocks - 1; i >= 0; i--) {
2356                 if (!adev->ip_blocks[i].status.hw)
2357                         continue;
2358
2359                 r = adev->ip_blocks[i].version->funcs->hw_fini((void *)adev);
2360                 /* XXX handle errors */
2361                 if (r) {
2362                         DRM_DEBUG("hw_fini of IP block <%s> failed %d\n",
2363                                   adev->ip_blocks[i].version->funcs->name, r);
2364                 }
2365
2366                 adev->ip_blocks[i].status.hw = false;
2367         }
2368
2369
2370         for (i = adev->num_ip_blocks - 1; i >= 0; i--) {
2371                 if (!adev->ip_blocks[i].status.sw)
2372                         continue;
2373
2374                 if (adev->ip_blocks[i].version->type == AMD_IP_BLOCK_TYPE_GMC) {
2375                         amdgpu_ucode_free_bo(adev);
2376                         amdgpu_free_static_csa(&adev->virt.csa_obj);
2377                         amdgpu_device_wb_fini(adev);
2378                         amdgpu_device_vram_scratch_fini(adev);
2379                         amdgpu_ib_pool_fini(adev);
2380                 }
2381
2382                 r = adev->ip_blocks[i].version->funcs->sw_fini((void *)adev);
2383                 /* XXX handle errors */
2384                 if (r) {
2385                         DRM_DEBUG("sw_fini of IP block <%s> failed %d\n",
2386                                   adev->ip_blocks[i].version->funcs->name, r);
2387                 }
2388                 adev->ip_blocks[i].status.sw = false;
2389                 adev->ip_blocks[i].status.valid = false;
2390         }
2391
2392         for (i = adev->num_ip_blocks - 1; i >= 0; i--) {
2393                 if (!adev->ip_blocks[i].status.late_initialized)
2394                         continue;
2395                 if (adev->ip_blocks[i].version->funcs->late_fini)
2396                         adev->ip_blocks[i].version->funcs->late_fini((void *)adev);
2397                 adev->ip_blocks[i].status.late_initialized = false;
2398         }
2399
2400         amdgpu_ras_fini(adev);
2401
2402         if (amdgpu_sriov_vf(adev))
2403                 if (amdgpu_virt_release_full_gpu(adev, false))
2404                         DRM_ERROR("failed to release exclusive mode on fini\n");
2405
2406         return 0;
2407 }
2408
2409 /**
2410  * amdgpu_device_delayed_init_work_handler - work handler for IB tests
2411  *
2412  * @work: work_struct.
2413  */
2414 static void amdgpu_device_delayed_init_work_handler(struct work_struct *work)
2415 {
2416         struct amdgpu_device *adev =
2417                 container_of(work, struct amdgpu_device, delayed_init_work.work);
2418         int r;
2419
2420         r = amdgpu_ib_ring_tests(adev);
2421         if (r)
2422                 DRM_ERROR("ib ring test failed (%d).\n", r);
2423 }
2424
2425 static void amdgpu_device_delay_enable_gfx_off(struct work_struct *work)
2426 {
2427         struct amdgpu_device *adev =
2428                 container_of(work, struct amdgpu_device, gfx.gfx_off_delay_work.work);
2429
2430         mutex_lock(&adev->gfx.gfx_off_mutex);
2431         if (!adev->gfx.gfx_off_state && !adev->gfx.gfx_off_req_count) {
2432                 if (!amdgpu_dpm_set_powergating_by_smu(adev, AMD_IP_BLOCK_TYPE_GFX, true))
2433                         adev->gfx.gfx_off_state = true;
2434         }
2435         mutex_unlock(&adev->gfx.gfx_off_mutex);
2436 }
2437
2438 /**
2439  * amdgpu_device_ip_suspend_phase1 - run suspend for hardware IPs (phase 1)
2440  *
2441  * @adev: amdgpu_device pointer
2442  *
2443  * Main suspend function for hardware IPs.  The list of all the hardware
2444  * IPs that make up the asic is walked, clockgating is disabled and the
2445  * suspend callbacks are run.  suspend puts the hardware and software state
2446  * in each IP into a state suitable for suspend.
2447  * Returns 0 on success, negative error code on failure.
2448  */
2449 static int amdgpu_device_ip_suspend_phase1(struct amdgpu_device *adev)
2450 {
2451         int i, r;
2452
2453         amdgpu_device_set_pg_state(adev, AMD_PG_STATE_UNGATE);
2454         amdgpu_device_set_cg_state(adev, AMD_CG_STATE_UNGATE);
2455
2456         for (i = adev->num_ip_blocks - 1; i >= 0; i--) {
2457                 if (!adev->ip_blocks[i].status.valid)
2458                         continue;
2459                 /* displays are handled separately */
2460                 if (adev->ip_blocks[i].version->type == AMD_IP_BLOCK_TYPE_DCE) {
2461                         /* XXX handle errors */
2462                         r = adev->ip_blocks[i].version->funcs->suspend(adev);
2463                         /* XXX handle errors */
2464                         if (r) {
2465                                 DRM_ERROR("suspend of IP block <%s> failed %d\n",
2466                                           adev->ip_blocks[i].version->funcs->name, r);
2467                                 return r;
2468                         }
2469                         adev->ip_blocks[i].status.hw = false;
2470                 }
2471         }
2472
2473         return 0;
2474 }
2475
2476 /**
2477  * amdgpu_device_ip_suspend_phase2 - run suspend for hardware IPs (phase 2)
2478  *
2479  * @adev: amdgpu_device pointer
2480  *
2481  * Main suspend function for hardware IPs.  The list of all the hardware
2482  * IPs that make up the asic is walked, clockgating is disabled and the
2483  * suspend callbacks are run.  suspend puts the hardware and software state
2484  * in each IP into a state suitable for suspend.
2485  * Returns 0 on success, negative error code on failure.
2486  */
2487 static int amdgpu_device_ip_suspend_phase2(struct amdgpu_device *adev)
2488 {
2489         int i, r;
2490
2491         for (i = adev->num_ip_blocks - 1; i >= 0; i--) {
2492                 if (!adev->ip_blocks[i].status.valid)
2493                         continue;
2494                 /* displays are handled in phase1 */
2495                 if (adev->ip_blocks[i].version->type == AMD_IP_BLOCK_TYPE_DCE)
2496                         continue;
2497                 /* PSP lost connection when err_event_athub occurs */
2498                 if (amdgpu_ras_intr_triggered() &&
2499                     adev->ip_blocks[i].version->type == AMD_IP_BLOCK_TYPE_PSP) {
2500                         adev->ip_blocks[i].status.hw = false;
2501                         continue;
2502                 }
2503                 /* XXX handle errors */
2504                 r = adev->ip_blocks[i].version->funcs->suspend(adev);
2505                 /* XXX handle errors */
2506                 if (r) {
2507                         DRM_ERROR("suspend of IP block <%s> failed %d\n",
2508                                   adev->ip_blocks[i].version->funcs->name, r);
2509                 }
2510                 adev->ip_blocks[i].status.hw = false;
2511                 /* handle putting the SMC in the appropriate state */
2512                 if(!amdgpu_sriov_vf(adev)){
2513                         if (adev->ip_blocks[i].version->type == AMD_IP_BLOCK_TYPE_SMC) {
2514                                 r = amdgpu_dpm_set_mp1_state(adev, adev->mp1_state);
2515                                 if (r) {
2516                                         DRM_ERROR("SMC failed to set mp1 state %d, %d\n",
2517                                                         adev->mp1_state, r);
2518                                         return r;
2519                                 }
2520                         }
2521                 }
2522                 adev->ip_blocks[i].status.hw = false;
2523         }
2524
2525         return 0;
2526 }
2527
2528 /**
2529  * amdgpu_device_ip_suspend - run suspend for hardware IPs
2530  *
2531  * @adev: amdgpu_device pointer
2532  *
2533  * Main suspend function for hardware IPs.  The list of all the hardware
2534  * IPs that make up the asic is walked, clockgating is disabled and the
2535  * suspend callbacks are run.  suspend puts the hardware and software state
2536  * in each IP into a state suitable for suspend.
2537  * Returns 0 on success, negative error code on failure.
2538  */
2539 int amdgpu_device_ip_suspend(struct amdgpu_device *adev)
2540 {
2541         int r;
2542
2543         if (amdgpu_sriov_vf(adev))
2544                 amdgpu_virt_request_full_gpu(adev, false);
2545
2546         r = amdgpu_device_ip_suspend_phase1(adev);
2547         if (r)
2548                 return r;
2549         r = amdgpu_device_ip_suspend_phase2(adev);
2550
2551         if (amdgpu_sriov_vf(adev))
2552                 amdgpu_virt_release_full_gpu(adev, false);
2553
2554         return r;
2555 }
2556
2557 static int amdgpu_device_ip_reinit_early_sriov(struct amdgpu_device *adev)
2558 {
2559         int i, r;
2560
2561         static enum amd_ip_block_type ip_order[] = {
2562                 AMD_IP_BLOCK_TYPE_GMC,
2563                 AMD_IP_BLOCK_TYPE_COMMON,
2564                 AMD_IP_BLOCK_TYPE_PSP,
2565                 AMD_IP_BLOCK_TYPE_IH,
2566         };
2567
2568         for (i = 0; i < ARRAY_SIZE(ip_order); i++) {
2569                 int j;
2570                 struct amdgpu_ip_block *block;
2571
2572                 for (j = 0; j < adev->num_ip_blocks; j++) {
2573                         block = &adev->ip_blocks[j];
2574
2575                         block->status.hw = false;
2576                         if (block->version->type != ip_order[i] ||
2577                                 !block->status.valid)
2578                                 continue;
2579
2580                         r = block->version->funcs->hw_init(adev);
2581                         DRM_INFO("RE-INIT-early: %s %s\n", block->version->funcs->name, r?"failed":"succeeded");
2582                         if (r)
2583                                 return r;
2584                         block->status.hw = true;
2585                 }
2586         }
2587
2588         return 0;
2589 }
2590
2591 static int amdgpu_device_ip_reinit_late_sriov(struct amdgpu_device *adev)
2592 {
2593         int i, r;
2594
2595         static enum amd_ip_block_type ip_order[] = {
2596                 AMD_IP_BLOCK_TYPE_SMC,
2597                 AMD_IP_BLOCK_TYPE_DCE,
2598                 AMD_IP_BLOCK_TYPE_GFX,
2599                 AMD_IP_BLOCK_TYPE_SDMA,
2600                 AMD_IP_BLOCK_TYPE_UVD,
2601                 AMD_IP_BLOCK_TYPE_VCE,
2602                 AMD_IP_BLOCK_TYPE_VCN
2603         };
2604
2605         for (i = 0; i < ARRAY_SIZE(ip_order); i++) {
2606                 int j;
2607                 struct amdgpu_ip_block *block;
2608
2609                 for (j = 0; j < adev->num_ip_blocks; j++) {
2610                         block = &adev->ip_blocks[j];
2611
2612                         if (block->version->type != ip_order[i] ||
2613                                 !block->status.valid ||
2614                                 block->status.hw)
2615                                 continue;
2616
2617                         if (block->version->type == AMD_IP_BLOCK_TYPE_SMC)
2618                                 r = block->version->funcs->resume(adev);
2619                         else
2620                                 r = block->version->funcs->hw_init(adev);
2621
2622                         DRM_INFO("RE-INIT-late: %s %s\n", block->version->funcs->name, r?"failed":"succeeded");
2623                         if (r)
2624                                 return r;
2625                         block->status.hw = true;
2626                 }
2627         }
2628
2629         return 0;
2630 }
2631
2632 /**
2633  * amdgpu_device_ip_resume_phase1 - run resume for hardware IPs
2634  *
2635  * @adev: amdgpu_device pointer
2636  *
2637  * First resume function for hardware IPs.  The list of all the hardware
2638  * IPs that make up the asic is walked and the resume callbacks are run for
2639  * COMMON, GMC, and IH.  resume puts the hardware into a functional state
2640  * after a suspend and updates the software state as necessary.  This
2641  * function is also used for restoring the GPU after a GPU reset.
2642  * Returns 0 on success, negative error code on failure.
2643  */
2644 static int amdgpu_device_ip_resume_phase1(struct amdgpu_device *adev)
2645 {
2646         int i, r;
2647
2648         for (i = 0; i < adev->num_ip_blocks; i++) {
2649                 if (!adev->ip_blocks[i].status.valid || adev->ip_blocks[i].status.hw)
2650                         continue;
2651                 if (adev->ip_blocks[i].version->type == AMD_IP_BLOCK_TYPE_COMMON ||
2652                     adev->ip_blocks[i].version->type == AMD_IP_BLOCK_TYPE_GMC ||
2653                     adev->ip_blocks[i].version->type == AMD_IP_BLOCK_TYPE_IH) {
2654
2655                         r = adev->ip_blocks[i].version->funcs->resume(adev);
2656                         if (r) {
2657                                 DRM_ERROR("resume of IP block <%s> failed %d\n",
2658                                           adev->ip_blocks[i].version->funcs->name, r);
2659                                 return r;
2660                         }
2661                         adev->ip_blocks[i].status.hw = true;
2662                 }
2663         }
2664
2665         return 0;
2666 }
2667
2668 /**
2669  * amdgpu_device_ip_resume_phase2 - run resume for hardware IPs
2670  *
2671  * @adev: amdgpu_device pointer
2672  *
2673  * First resume function for hardware IPs.  The list of all the hardware
2674  * IPs that make up the asic is walked and the resume callbacks are run for
2675  * all blocks except COMMON, GMC, and IH.  resume puts the hardware into a
2676  * functional state after a suspend and updates the software state as
2677  * necessary.  This function is also used for restoring the GPU after a GPU
2678  * reset.
2679  * Returns 0 on success, negative error code on failure.
2680  */
2681 static int amdgpu_device_ip_resume_phase2(struct amdgpu_device *adev)
2682 {
2683         int i, r;
2684
2685         for (i = 0; i < adev->num_ip_blocks; i++) {
2686                 if (!adev->ip_blocks[i].status.valid || adev->ip_blocks[i].status.hw)
2687                         continue;
2688                 if (adev->ip_blocks[i].version->type == AMD_IP_BLOCK_TYPE_COMMON ||
2689                     adev->ip_blocks[i].version->type == AMD_IP_BLOCK_TYPE_GMC ||
2690                     adev->ip_blocks[i].version->type == AMD_IP_BLOCK_TYPE_IH ||
2691                     adev->ip_blocks[i].version->type == AMD_IP_BLOCK_TYPE_PSP)
2692                         continue;
2693                 r = adev->ip_blocks[i].version->funcs->resume(adev);
2694                 if (r) {
2695                         DRM_ERROR("resume of IP block <%s> failed %d\n",
2696                                   adev->ip_blocks[i].version->funcs->name, r);
2697                         return r;
2698                 }
2699                 adev->ip_blocks[i].status.hw = true;
2700         }
2701
2702         return 0;
2703 }
2704
2705 /**
2706  * amdgpu_device_ip_resume - run resume for hardware IPs
2707  *
2708  * @adev: amdgpu_device pointer
2709  *
2710  * Main resume function for hardware IPs.  The hardware IPs
2711  * are split into two resume functions because they are
2712  * are also used in in recovering from a GPU reset and some additional
2713  * steps need to be take between them.  In this case (S3/S4) they are
2714  * run sequentially.
2715  * Returns 0 on success, negative error code on failure.
2716  */
2717 static int amdgpu_device_ip_resume(struct amdgpu_device *adev)
2718 {
2719         int r;
2720
2721         r = amdgpu_device_ip_resume_phase1(adev);
2722         if (r)
2723                 return r;
2724
2725         r = amdgpu_device_fw_loading(adev);
2726         if (r)
2727                 return r;
2728
2729         r = amdgpu_device_ip_resume_phase2(adev);
2730
2731         return r;
2732 }
2733
2734 /**
2735  * amdgpu_device_detect_sriov_bios - determine if the board supports SR-IOV
2736  *
2737  * @adev: amdgpu_device pointer
2738  *
2739  * Query the VBIOS data tables to determine if the board supports SR-IOV.
2740  */
2741 static void amdgpu_device_detect_sriov_bios(struct amdgpu_device *adev)
2742 {
2743         if (amdgpu_sriov_vf(adev)) {
2744                 if (adev->is_atom_fw) {
2745                         if (amdgpu_atomfirmware_gpu_supports_virtualization(adev))
2746                                 adev->virt.caps |= AMDGPU_SRIOV_CAPS_SRIOV_VBIOS;
2747                 } else {
2748                         if (amdgpu_atombios_has_gpu_virtualization_table(adev))
2749                                 adev->virt.caps |= AMDGPU_SRIOV_CAPS_SRIOV_VBIOS;
2750                 }
2751
2752                 if (!(adev->virt.caps & AMDGPU_SRIOV_CAPS_SRIOV_VBIOS))
2753                         amdgpu_vf_error_put(adev, AMDGIM_ERROR_VF_NO_VBIOS, 0, 0);
2754         }
2755 }
2756
2757 /**
2758  * amdgpu_device_asic_has_dc_support - determine if DC supports the asic
2759  *
2760  * @asic_type: AMD asic type
2761  *
2762  * Check if there is DC (new modesetting infrastructre) support for an asic.
2763  * returns true if DC has support, false if not.
2764  */
2765 bool amdgpu_device_asic_has_dc_support(enum amd_asic_type asic_type)
2766 {
2767         switch (asic_type) {
2768 #if defined(CONFIG_DRM_AMD_DC)
2769         case CHIP_BONAIRE:
2770         case CHIP_KAVERI:
2771         case CHIP_KABINI:
2772         case CHIP_MULLINS:
2773                 /*
2774                  * We have systems in the wild with these ASICs that require
2775                  * LVDS and VGA support which is not supported with DC.
2776                  *
2777                  * Fallback to the non-DC driver here by default so as not to
2778                  * cause regressions.
2779                  */
2780                 return amdgpu_dc > 0;
2781         case CHIP_HAWAII:
2782         case CHIP_CARRIZO:
2783         case CHIP_STONEY:
2784         case CHIP_POLARIS10:
2785         case CHIP_POLARIS11:
2786         case CHIP_POLARIS12:
2787         case CHIP_VEGAM:
2788         case CHIP_TONGA:
2789         case CHIP_FIJI:
2790         case CHIP_VEGA10:
2791         case CHIP_VEGA12:
2792         case CHIP_VEGA20:
2793 #if defined(CONFIG_DRM_AMD_DC_DCN)
2794         case CHIP_RAVEN:
2795         case CHIP_NAVI10:
2796         case CHIP_NAVI14:
2797         case CHIP_NAVI12:
2798         case CHIP_RENOIR:
2799 #endif
2800 #if defined(CONFIG_DRM_AMD_DC_DCN3_0)
2801         case CHIP_SIENNA_CICHLID:
2802 #endif
2803                 return amdgpu_dc != 0;
2804 #endif
2805         default:
2806                 if (amdgpu_dc > 0)
2807                         DRM_INFO("Display Core has been requested via kernel parameter "
2808                                          "but isn't supported by ASIC, ignoring\n");
2809                 return false;
2810         }
2811 }
2812
2813 /**
2814  * amdgpu_device_has_dc_support - check if dc is supported
2815  *
2816  * @adev: amdgpu_device_pointer
2817  *
2818  * Returns true for supported, false for not supported
2819  */
2820 bool amdgpu_device_has_dc_support(struct amdgpu_device *adev)
2821 {
2822         if (amdgpu_sriov_vf(adev))
2823                 return false;
2824
2825         return amdgpu_device_asic_has_dc_support(adev->asic_type);
2826 }
2827
2828
2829 static void amdgpu_device_xgmi_reset_func(struct work_struct *__work)
2830 {
2831         struct amdgpu_device *adev =
2832                 container_of(__work, struct amdgpu_device, xgmi_reset_work);
2833         struct amdgpu_hive_info *hive = amdgpu_get_xgmi_hive(adev, 0);
2834
2835         /* It's a bug to not have a hive within this function */
2836         if (WARN_ON(!hive))
2837                 return;
2838
2839         /*
2840          * Use task barrier to synchronize all xgmi reset works across the
2841          * hive. task_barrier_enter and task_barrier_exit will block
2842          * until all the threads running the xgmi reset works reach
2843          * those points. task_barrier_full will do both blocks.
2844          */
2845         if (amdgpu_asic_reset_method(adev) == AMD_RESET_METHOD_BACO) {
2846
2847                 task_barrier_enter(&hive->tb);
2848                 adev->asic_reset_res = amdgpu_device_baco_enter(adev->ddev);
2849
2850                 if (adev->asic_reset_res)
2851                         goto fail;
2852
2853                 task_barrier_exit(&hive->tb);
2854                 adev->asic_reset_res = amdgpu_device_baco_exit(adev->ddev);
2855
2856                 if (adev->asic_reset_res)
2857                         goto fail;
2858
2859                 if (adev->mmhub.funcs && adev->mmhub.funcs->reset_ras_error_count)
2860                         adev->mmhub.funcs->reset_ras_error_count(adev);
2861         } else {
2862
2863                 task_barrier_full(&hive->tb);
2864                 adev->asic_reset_res =  amdgpu_asic_reset(adev);
2865         }
2866
2867 fail:
2868         if (adev->asic_reset_res)
2869                 DRM_WARN("ASIC reset failed with error, %d for drm dev, %s",
2870                          adev->asic_reset_res, adev->ddev->unique);
2871 }
2872
2873 static int amdgpu_device_get_job_timeout_settings(struct amdgpu_device *adev)
2874 {
2875         char *input = amdgpu_lockup_timeout;
2876         char *timeout_setting = NULL;
2877         int index = 0;
2878         long timeout;
2879         int ret = 0;
2880
2881         /*
2882          * By default timeout for non compute jobs is 10000.
2883          * And there is no timeout enforced on compute jobs.
2884          * In SR-IOV or passthrough mode, timeout for compute
2885          * jobs are 60000 by default.
2886          */
2887         adev->gfx_timeout = msecs_to_jiffies(10000);
2888         adev->sdma_timeout = adev->video_timeout = adev->gfx_timeout;
2889         if (amdgpu_sriov_vf(adev) || amdgpu_passthrough(adev))
2890                 adev->compute_timeout =  msecs_to_jiffies(60000);
2891         else
2892                 adev->compute_timeout = MAX_SCHEDULE_TIMEOUT;
2893
2894         if (strnlen(input, AMDGPU_MAX_TIMEOUT_PARAM_LENGTH)) {
2895                 while ((timeout_setting = strsep(&input, ",")) &&
2896                                 strnlen(timeout_setting, AMDGPU_MAX_TIMEOUT_PARAM_LENGTH)) {
2897                         ret = kstrtol(timeout_setting, 0, &timeout);
2898                         if (ret)
2899                                 return ret;
2900
2901                         if (timeout == 0) {
2902                                 index++;
2903                                 continue;
2904                         } else if (timeout < 0) {
2905                                 timeout = MAX_SCHEDULE_TIMEOUT;
2906                         } else {
2907                                 timeout = msecs_to_jiffies(timeout);
2908                         }
2909
2910                         switch (index++) {
2911                         case 0:
2912                                 adev->gfx_timeout = timeout;
2913                                 break;
2914                         case 1:
2915                                 adev->compute_timeout = timeout;
2916                                 break;
2917                         case 2:
2918                                 adev->sdma_timeout = timeout;
2919                                 break;
2920                         case 3:
2921                                 adev->video_timeout = timeout;
2922                                 break;
2923                         default:
2924                                 break;
2925                         }
2926                 }
2927                 /*
2928                  * There is only one value specified and
2929                  * it should apply to all non-compute jobs.
2930                  */
2931                 if (index == 1) {
2932                         adev->sdma_timeout = adev->video_timeout = adev->gfx_timeout;
2933                         if (amdgpu_sriov_vf(adev) || amdgpu_passthrough(adev))
2934                                 adev->compute_timeout = adev->gfx_timeout;
2935                 }
2936         }
2937
2938         return ret;
2939 }
2940
2941 static const struct attribute *amdgpu_dev_attributes[] = {
2942         &dev_attr_product_name.attr,
2943         &dev_attr_product_number.attr,
2944         &dev_attr_serial_number.attr,
2945         &dev_attr_pcie_replay_count.attr,
2946         NULL
2947 };
2948
2949 /**
2950  * amdgpu_device_init - initialize the driver
2951  *
2952  * @adev: amdgpu_device pointer
2953  * @ddev: drm dev pointer
2954  * @pdev: pci dev pointer
2955  * @flags: driver flags
2956  *
2957  * Initializes the driver info and hw (all asics).
2958  * Returns 0 for success or an error on failure.
2959  * Called at driver startup.
2960  */
2961 int amdgpu_device_init(struct amdgpu_device *adev,
2962                        struct drm_device *ddev,
2963                        struct pci_dev *pdev,
2964                        uint32_t flags)
2965 {
2966         int r, i;
2967         bool boco = false;
2968         u32 max_MBps;
2969
2970         adev->shutdown = false;
2971         adev->dev = &pdev->dev;
2972         adev->ddev = ddev;
2973         adev->pdev = pdev;
2974         adev->flags = flags;
2975
2976         if (amdgpu_force_asic_type >= 0 && amdgpu_force_asic_type < CHIP_LAST)
2977                 adev->asic_type = amdgpu_force_asic_type;
2978         else
2979                 adev->asic_type = flags & AMD_ASIC_MASK;
2980
2981         adev->usec_timeout = AMDGPU_MAX_USEC_TIMEOUT;
2982         if (amdgpu_emu_mode == 1)
2983                 adev->usec_timeout *= 10;
2984         adev->gmc.gart_size = 512 * 1024 * 1024;
2985         adev->accel_working = false;
2986         adev->num_rings = 0;
2987         adev->mman.buffer_funcs = NULL;
2988         adev->mman.buffer_funcs_ring = NULL;
2989         adev->vm_manager.vm_pte_funcs = NULL;
2990         adev->vm_manager.vm_pte_num_scheds = 0;
2991         adev->gmc.gmc_funcs = NULL;
2992         adev->fence_context = dma_fence_context_alloc(AMDGPU_MAX_RINGS);
2993         bitmap_zero(adev->gfx.pipe_reserve_bitmap, AMDGPU_MAX_COMPUTE_QUEUES);
2994
2995         adev->smc_rreg = &amdgpu_invalid_rreg;
2996         adev->smc_wreg = &amdgpu_invalid_wreg;
2997         adev->pcie_rreg = &amdgpu_invalid_rreg;
2998         adev->pcie_wreg = &amdgpu_invalid_wreg;
2999         adev->pciep_rreg = &amdgpu_invalid_rreg;
3000         adev->pciep_wreg = &amdgpu_invalid_wreg;
3001         adev->pcie_rreg64 = &amdgpu_invalid_rreg64;
3002         adev->pcie_wreg64 = &amdgpu_invalid_wreg64;
3003         adev->uvd_ctx_rreg = &amdgpu_invalid_rreg;
3004         adev->uvd_ctx_wreg = &amdgpu_invalid_wreg;
3005         adev->didt_rreg = &amdgpu_invalid_rreg;
3006         adev->didt_wreg = &amdgpu_invalid_wreg;
3007         adev->gc_cac_rreg = &amdgpu_invalid_rreg;
3008         adev->gc_cac_wreg = &amdgpu_invalid_wreg;
3009         adev->audio_endpt_rreg = &amdgpu_block_invalid_rreg;
3010         adev->audio_endpt_wreg = &amdgpu_block_invalid_wreg;
3011
3012         DRM_INFO("initializing kernel modesetting (%s 0x%04X:0x%04X 0x%04X:0x%04X 0x%02X).\n",
3013                  amdgpu_asic_name[adev->asic_type], pdev->vendor, pdev->device,
3014                  pdev->subsystem_vendor, pdev->subsystem_device, pdev->revision);
3015
3016         /* mutex initialization are all done here so we
3017          * can recall function without having locking issues */
3018         atomic_set(&adev->irq.ih.lock, 0);
3019         mutex_init(&adev->firmware.mutex);
3020         mutex_init(&adev->pm.mutex);
3021         mutex_init(&adev->gfx.gpu_clock_mutex);
3022         mutex_init(&adev->srbm_mutex);
3023         mutex_init(&adev->gfx.pipe_reserve_mutex);
3024         mutex_init(&adev->gfx.gfx_off_mutex);
3025         mutex_init(&adev->grbm_idx_mutex);
3026         mutex_init(&adev->mn_lock);
3027         mutex_init(&adev->virt.vf_errors.lock);
3028         hash_init(adev->mn_hash);
3029         mutex_init(&adev->lock_reset);
3030         mutex_init(&adev->psp.mutex);
3031         mutex_init(&adev->notifier_lock);
3032
3033         r = amdgpu_device_check_arguments(adev);
3034         if (r)
3035                 return r;
3036
3037         spin_lock_init(&adev->mmio_idx_lock);
3038         spin_lock_init(&adev->smc_idx_lock);
3039         spin_lock_init(&adev->pcie_idx_lock);
3040         spin_lock_init(&adev->uvd_ctx_idx_lock);
3041         spin_lock_init(&adev->didt_idx_lock);
3042         spin_lock_init(&adev->gc_cac_idx_lock);
3043         spin_lock_init(&adev->se_cac_idx_lock);
3044         spin_lock_init(&adev->audio_endpt_idx_lock);
3045         spin_lock_init(&adev->mm_stats.lock);
3046
3047         INIT_LIST_HEAD(&adev->shadow_list);
3048         mutex_init(&adev->shadow_list_lock);
3049
3050         INIT_DELAYED_WORK(&adev->delayed_init_work,
3051                           amdgpu_device_delayed_init_work_handler);
3052         INIT_DELAYED_WORK(&adev->gfx.gfx_off_delay_work,
3053                           amdgpu_device_delay_enable_gfx_off);
3054
3055         INIT_WORK(&adev->xgmi_reset_work, amdgpu_device_xgmi_reset_func);
3056
3057         adev->gfx.gfx_off_req_count = 1;
3058         adev->pm.ac_power = power_supply_is_system_supplied() > 0;
3059
3060         atomic_set(&adev->throttling_logging_enabled, 1);
3061         /*
3062          * If throttling continues, logging will be performed every minute
3063          * to avoid log flooding. "-1" is subtracted since the thermal
3064          * throttling interrupt comes every second. Thus, the total logging
3065          * interval is 59 seconds(retelimited printk interval) + 1(waiting
3066          * for throttling interrupt) = 60 seconds.
3067          */
3068         ratelimit_state_init(&adev->throttling_logging_rs, (60 - 1) * HZ, 1);
3069         ratelimit_set_flags(&adev->throttling_logging_rs, RATELIMIT_MSG_ON_RELEASE);
3070
3071         /* Registers mapping */
3072         /* TODO: block userspace mapping of io register */
3073         if (adev->asic_type >= CHIP_BONAIRE) {
3074                 adev->rmmio_base = pci_resource_start(adev->pdev, 5);
3075                 adev->rmmio_size = pci_resource_len(adev->pdev, 5);
3076         } else {
3077                 adev->rmmio_base = pci_resource_start(adev->pdev, 2);
3078                 adev->rmmio_size = pci_resource_len(adev->pdev, 2);
3079         }
3080
3081         adev->rmmio = ioremap(adev->rmmio_base, adev->rmmio_size);
3082         if (adev->rmmio == NULL) {
3083                 return -ENOMEM;
3084         }
3085         DRM_INFO("register mmio base: 0x%08X\n", (uint32_t)adev->rmmio_base);
3086         DRM_INFO("register mmio size: %u\n", (unsigned)adev->rmmio_size);
3087
3088         /* io port mapping */
3089         for (i = 0; i < DEVICE_COUNT_RESOURCE; i++) {
3090                 if (pci_resource_flags(adev->pdev, i) & IORESOURCE_IO) {
3091                         adev->rio_mem_size = pci_resource_len(adev->pdev, i);
3092                         adev->rio_mem = pci_iomap(adev->pdev, i, adev->rio_mem_size);
3093                         break;
3094                 }
3095         }
3096         if (adev->rio_mem == NULL)
3097                 DRM_INFO("PCI I/O BAR is not found.\n");
3098
3099         /* enable PCIE atomic ops */
3100         r = pci_enable_atomic_ops_to_root(adev->pdev,
3101                                           PCI_EXP_DEVCAP2_ATOMIC_COMP32 |
3102                                           PCI_EXP_DEVCAP2_ATOMIC_COMP64);
3103         if (r) {
3104                 adev->have_atomics_support = false;
3105                 DRM_INFO("PCIE atomic ops is not supported\n");
3106         } else {
3107                 adev->have_atomics_support = true;
3108         }
3109
3110         amdgpu_device_get_pcie_info(adev);
3111
3112         if (amdgpu_mcbp)
3113                 DRM_INFO("MCBP is enabled\n");
3114
3115         if (amdgpu_mes && adev->asic_type >= CHIP_NAVI10)
3116                 adev->enable_mes = true;
3117
3118         /* detect hw virtualization here */
3119         amdgpu_detect_virtualization(adev);
3120
3121         r = amdgpu_device_get_job_timeout_settings(adev);
3122         if (r) {
3123                 dev_err(adev->dev, "invalid lockup_timeout parameter syntax\n");
3124                 return r;
3125         }
3126
3127         /* early init functions */
3128         r = amdgpu_device_ip_early_init(adev);
3129         if (r)
3130                 return r;
3131
3132         /* doorbell bar mapping and doorbell index init*/
3133         amdgpu_device_doorbell_init(adev);
3134
3135         /* if we have > 1 VGA cards, then disable the amdgpu VGA resources */
3136         /* this will fail for cards that aren't VGA class devices, just
3137          * ignore it */
3138         vga_client_register(adev->pdev, adev, NULL, amdgpu_device_vga_set_decode);
3139
3140         if (amdgpu_device_supports_boco(ddev))
3141                 boco = true;
3142         if (amdgpu_has_atpx() &&
3143             (amdgpu_is_atpx_hybrid() ||
3144              amdgpu_has_atpx_dgpu_power_cntl()) &&
3145             !pci_is_thunderbolt_attached(adev->pdev))
3146                 vga_switcheroo_register_client(adev->pdev,
3147                                                &amdgpu_switcheroo_ops, boco);
3148         if (boco)
3149                 vga_switcheroo_init_domain_pm_ops(adev->dev, &adev->vga_pm_domain);
3150
3151         if (amdgpu_emu_mode == 1) {
3152                 /* post the asic on emulation mode */
3153                 emu_soc_asic_init(adev);
3154                 goto fence_driver_init;
3155         }
3156
3157         /* detect if we are with an SRIOV vbios */
3158         amdgpu_device_detect_sriov_bios(adev);
3159
3160         /* check if we need to reset the asic
3161          *  E.g., driver was not cleanly unloaded previously, etc.
3162          */
3163         if (!amdgpu_sriov_vf(adev) && amdgpu_asic_need_reset_on_init(adev)) {
3164                 r = amdgpu_asic_reset(adev);
3165                 if (r) {
3166                         dev_err(adev->dev, "asic reset on init failed\n");
3167                         goto failed;
3168                 }
3169         }
3170
3171         /* Post card if necessary */
3172         if (amdgpu_device_need_post(adev)) {
3173                 if (!adev->bios) {
3174                         dev_err(adev->dev, "no vBIOS found\n");
3175                         r = -EINVAL;
3176                         goto failed;
3177                 }
3178                 DRM_INFO("GPU posting now...\n");
3179                 r = amdgpu_atom_asic_init(adev->mode_info.atom_context);
3180                 if (r) {
3181                         dev_err(adev->dev, "gpu post error!\n");
3182                         goto failed;
3183                 }
3184         }
3185
3186         if (adev->is_atom_fw) {
3187                 /* Initialize clocks */
3188                 r = amdgpu_atomfirmware_get_clock_info(adev);
3189                 if (r) {
3190                         dev_err(adev->dev, "amdgpu_atomfirmware_get_clock_info failed\n");
3191                         amdgpu_vf_error_put(adev, AMDGIM_ERROR_VF_ATOMBIOS_GET_CLOCK_FAIL, 0, 0);
3192                         goto failed;
3193                 }
3194         } else {
3195                 /* Initialize clocks */
3196                 r = amdgpu_atombios_get_clock_info(adev);
3197                 if (r) {
3198                         dev_err(adev->dev, "amdgpu_atombios_get_clock_info failed\n");
3199                         amdgpu_vf_error_put(adev, AMDGIM_ERROR_VF_ATOMBIOS_GET_CLOCK_FAIL, 0, 0);
3200                         goto failed;
3201                 }
3202                 /* init i2c buses */
3203                 if (!amdgpu_device_has_dc_support(adev))
3204                         amdgpu_atombios_i2c_init(adev);
3205         }
3206
3207 fence_driver_init:
3208         /* Fence driver */
3209         r = amdgpu_fence_driver_init(adev);
3210         if (r) {
3211                 dev_err(adev->dev, "amdgpu_fence_driver_init failed\n");
3212                 amdgpu_vf_error_put(adev, AMDGIM_ERROR_VF_FENCE_INIT_FAIL, 0, 0);
3213                 goto failed;
3214         }
3215
3216         /* init the mode config */
3217         drm_mode_config_init(adev->ddev);
3218
3219         r = amdgpu_device_ip_init(adev);
3220         if (r) {
3221                 /* failed in exclusive mode due to timeout */
3222                 if (amdgpu_sriov_vf(adev) &&
3223                     !amdgpu_sriov_runtime(adev) &&
3224                     amdgpu_virt_mmio_blocked(adev) &&
3225                     !amdgpu_virt_wait_reset(adev)) {
3226                         dev_err(adev->dev, "VF exclusive mode timeout\n");
3227                         /* Don't send request since VF is inactive. */
3228                         adev->virt.caps &= ~AMDGPU_SRIOV_CAPS_RUNTIME;
3229                         adev->virt.ops = NULL;
3230                         r = -EAGAIN;
3231                         goto failed;
3232                 }
3233                 dev_err(adev->dev, "amdgpu_device_ip_init failed\n");
3234                 amdgpu_vf_error_put(adev, AMDGIM_ERROR_VF_AMDGPU_INIT_FAIL, 0, 0);
3235                 goto failed;
3236         }
3237
3238         dev_info(adev->dev,
3239                 "SE %d, SH per SE %d, CU per SH %d, active_cu_number %d\n",
3240                         adev->gfx.config.max_shader_engines,
3241                         adev->gfx.config.max_sh_per_se,
3242                         adev->gfx.config.max_cu_per_sh,
3243                         adev->gfx.cu_info.number);
3244
3245         adev->accel_working = true;
3246
3247         amdgpu_vm_check_compute_bug(adev);
3248
3249         /* Initialize the buffer migration limit. */
3250         if (amdgpu_moverate >= 0)
3251                 max_MBps = amdgpu_moverate;
3252         else
3253                 max_MBps = 8; /* Allow 8 MB/s. */
3254         /* Get a log2 for easy divisions. */
3255         adev->mm_stats.log2_max_MBps = ilog2(max(1u, max_MBps));
3256
3257         amdgpu_fbdev_init(adev);
3258
3259         r = amdgpu_pm_sysfs_init(adev);
3260         if (r) {
3261                 adev->pm_sysfs_en = false;
3262                 DRM_ERROR("registering pm debugfs failed (%d).\n", r);
3263         } else
3264                 adev->pm_sysfs_en = true;
3265
3266         r = amdgpu_ucode_sysfs_init(adev);
3267         if (r) {
3268                 adev->ucode_sysfs_en = false;
3269                 DRM_ERROR("Creating firmware sysfs failed (%d).\n", r);
3270         } else
3271                 adev->ucode_sysfs_en = true;
3272
3273         if ((amdgpu_testing & 1)) {
3274                 if (adev->accel_working)
3275                         amdgpu_test_moves(adev);
3276                 else
3277                         DRM_INFO("amdgpu: acceleration disabled, skipping move tests\n");
3278         }
3279         if (amdgpu_benchmarking) {
3280                 if (adev->accel_working)
3281                         amdgpu_benchmark(adev, amdgpu_benchmarking);
3282                 else
3283                         DRM_INFO("amdgpu: acceleration disabled, skipping benchmarks\n");
3284         }
3285
3286         /*
3287          * Register gpu instance before amdgpu_device_enable_mgpu_fan_boost.
3288          * Otherwise the mgpu fan boost feature will be skipped due to the
3289          * gpu instance is counted less.
3290          */
3291         amdgpu_register_gpu_instance(adev);
3292
3293         /* enable clockgating, etc. after ib tests, etc. since some blocks require
3294          * explicit gating rather than handling it automatically.
3295          */
3296         r = amdgpu_device_ip_late_init(adev);
3297         if (r) {
3298                 dev_err(adev->dev, "amdgpu_device_ip_late_init failed\n");
3299                 amdgpu_vf_error_put(adev, AMDGIM_ERROR_VF_AMDGPU_LATE_INIT_FAIL, 0, r);
3300                 goto failed;
3301         }
3302
3303         /* must succeed. */
3304         amdgpu_ras_resume(adev);
3305
3306         queue_delayed_work(system_wq, &adev->delayed_init_work,
3307                            msecs_to_jiffies(AMDGPU_RESUME_MS));
3308
3309         if (amdgpu_sriov_vf(adev))
3310                 flush_delayed_work(&adev->delayed_init_work);
3311
3312         r = sysfs_create_files(&adev->dev->kobj, amdgpu_dev_attributes);
3313         if (r) {
3314                 dev_err(adev->dev, "Could not create amdgpu device attr\n");
3315                 return r;
3316         }
3317
3318         if (IS_ENABLED(CONFIG_PERF_EVENTS))
3319                 r = amdgpu_pmu_init(adev);
3320         if (r)
3321                 dev_err(adev->dev, "amdgpu_pmu_init failed\n");
3322
3323         return 0;
3324
3325 failed:
3326         amdgpu_vf_error_trans_all(adev);
3327         if (boco)
3328                 vga_switcheroo_fini_domain_pm_ops(adev->dev);
3329
3330         return r;
3331 }
3332
3333 /**
3334  * amdgpu_device_fini - tear down the driver
3335  *
3336  * @adev: amdgpu_device pointer
3337  *
3338  * Tear down the driver info (all asics).
3339  * Called at driver shutdown.
3340  */
3341 void amdgpu_device_fini(struct amdgpu_device *adev)
3342 {
3343         int r;
3344
3345         DRM_INFO("amdgpu: finishing device.\n");
3346         flush_delayed_work(&adev->delayed_init_work);
3347         adev->shutdown = true;
3348
3349         /* make sure IB test finished before entering exclusive mode
3350          * to avoid preemption on IB test
3351          * */
3352         if (amdgpu_sriov_vf(adev))
3353                 amdgpu_virt_request_full_gpu(adev, false);
3354
3355         /* disable all interrupts */
3356         amdgpu_irq_disable_all(adev);
3357         if (adev->mode_info.mode_config_initialized){
3358                 if (!amdgpu_device_has_dc_support(adev))
3359                         drm_helper_force_disable_all(adev->ddev);
3360                 else
3361                         drm_atomic_helper_shutdown(adev->ddev);
3362         }
3363         amdgpu_fence_driver_fini(adev);
3364         if (adev->pm_sysfs_en)
3365                 amdgpu_pm_sysfs_fini(adev);
3366         amdgpu_fbdev_fini(adev);
3367         r = amdgpu_device_ip_fini(adev);
3368         release_firmware(adev->firmware.gpu_info_fw);
3369         adev->firmware.gpu_info_fw = NULL;
3370         adev->accel_working = false;
3371         /* free i2c buses */
3372         if (!amdgpu_device_has_dc_support(adev))
3373                 amdgpu_i2c_fini(adev);
3374
3375         if (amdgpu_emu_mode != 1)
3376                 amdgpu_atombios_fini(adev);
3377
3378         kfree(adev->bios);
3379         adev->bios = NULL;
3380         if (amdgpu_has_atpx() &&
3381             (amdgpu_is_atpx_hybrid() ||
3382              amdgpu_has_atpx_dgpu_power_cntl()) &&
3383             !pci_is_thunderbolt_attached(adev->pdev))
3384                 vga_switcheroo_unregister_client(adev->pdev);
3385         if (amdgpu_device_supports_boco(adev->ddev))
3386                 vga_switcheroo_fini_domain_pm_ops(adev->dev);
3387         vga_client_register(adev->pdev, NULL, NULL, NULL);
3388         if (adev->rio_mem)
3389                 pci_iounmap(adev->pdev, adev->rio_mem);
3390         adev->rio_mem = NULL;
3391         iounmap(adev->rmmio);
3392         adev->rmmio = NULL;
3393         amdgpu_device_doorbell_fini(adev);
3394
3395         if (adev->ucode_sysfs_en)
3396                 amdgpu_ucode_sysfs_fini(adev);
3397
3398         sysfs_remove_files(&adev->dev->kobj, amdgpu_dev_attributes);
3399         if (IS_ENABLED(CONFIG_PERF_EVENTS))
3400                 amdgpu_pmu_fini(adev);
3401         if (adev->discovery_bin)
3402                 amdgpu_discovery_fini(adev);
3403 }
3404
3405
3406 /*
3407  * Suspend & resume.
3408  */
3409 /**
3410  * amdgpu_device_suspend - initiate device suspend
3411  *
3412  * @dev: drm dev pointer
3413  * @fbcon : notify the fbdev of suspend
3414  *
3415  * Puts the hw in the suspend state (all asics).
3416  * Returns 0 for success or an error on failure.
3417  * Called at driver suspend.
3418  */
3419 int amdgpu_device_suspend(struct drm_device *dev, bool fbcon)
3420 {
3421         struct amdgpu_device *adev;
3422         struct drm_crtc *crtc;
3423         struct drm_connector *connector;
3424         struct drm_connector_list_iter iter;
3425         int r;
3426
3427         if (dev == NULL || dev->dev_private == NULL) {
3428                 return -ENODEV;
3429         }
3430
3431         adev = dev->dev_private;
3432
3433         if (dev->switch_power_state == DRM_SWITCH_POWER_OFF)
3434                 return 0;
3435
3436         adev->in_suspend = true;
3437         drm_kms_helper_poll_disable(dev);
3438
3439         if (fbcon)
3440                 amdgpu_fbdev_set_suspend(adev, 1);
3441
3442         cancel_delayed_work_sync(&adev->delayed_init_work);
3443
3444         if (!amdgpu_device_has_dc_support(adev)) {
3445                 /* turn off display hw */
3446                 drm_modeset_lock_all(dev);
3447                 drm_connector_list_iter_begin(dev, &iter);
3448                 drm_for_each_connector_iter(connector, &iter)
3449                         drm_helper_connector_dpms(connector,
3450                                                   DRM_MODE_DPMS_OFF);
3451                 drm_connector_list_iter_end(&iter);
3452                 drm_modeset_unlock_all(dev);
3453                         /* unpin the front buffers and cursors */
3454                 list_for_each_entry(crtc, &dev->mode_config.crtc_list, head) {
3455                         struct amdgpu_crtc *amdgpu_crtc = to_amdgpu_crtc(crtc);
3456                         struct drm_framebuffer *fb = crtc->primary->fb;
3457                         struct amdgpu_bo *robj;
3458
3459                         if (amdgpu_crtc->cursor_bo && !adev->enable_virtual_display) {
3460                                 struct amdgpu_bo *aobj = gem_to_amdgpu_bo(amdgpu_crtc->cursor_bo);
3461                                 r = amdgpu_bo_reserve(aobj, true);
3462                                 if (r == 0) {
3463                                         amdgpu_bo_unpin(aobj);
3464                                         amdgpu_bo_unreserve(aobj);
3465                                 }
3466                         }
3467
3468                         if (fb == NULL || fb->obj[0] == NULL) {
3469                                 continue;
3470                         }
3471                         robj = gem_to_amdgpu_bo(fb->obj[0]);
3472                         /* don't unpin kernel fb objects */
3473                         if (!amdgpu_fbdev_robj_is_fb(adev, robj)) {
3474                                 r = amdgpu_bo_reserve(robj, true);
3475                                 if (r == 0) {
3476                                         amdgpu_bo_unpin(robj);
3477                                         amdgpu_bo_unreserve(robj);
3478                                 }
3479                         }
3480                 }
3481         }
3482
3483         amdgpu_ras_suspend(adev);
3484
3485         r = amdgpu_device_ip_suspend_phase1(adev);
3486
3487         amdgpu_amdkfd_suspend(adev, !fbcon);
3488
3489         /* evict vram memory */
3490         amdgpu_bo_evict_vram(adev);
3491
3492         amdgpu_fence_driver_suspend(adev);
3493
3494         r = amdgpu_device_ip_suspend_phase2(adev);
3495
3496         /* evict remaining vram memory
3497          * This second call to evict vram is to evict the gart page table
3498          * using the CPU.
3499          */
3500         amdgpu_bo_evict_vram(adev);
3501
3502         return 0;
3503 }
3504
3505 /**
3506  * amdgpu_device_resume - initiate device resume
3507  *
3508  * @dev: drm dev pointer
3509  * @fbcon : notify the fbdev of resume
3510  *
3511  * Bring the hw back to operating state (all asics).
3512  * Returns 0 for success or an error on failure.
3513  * Called at driver resume.
3514  */
3515 int amdgpu_device_resume(struct drm_device *dev, bool fbcon)
3516 {
3517         struct drm_connector *connector;
3518         struct drm_connector_list_iter iter;
3519         struct amdgpu_device *adev = dev->dev_private;
3520         struct drm_crtc *crtc;
3521         int r = 0;
3522
3523         if (dev->switch_power_state == DRM_SWITCH_POWER_OFF)
3524                 return 0;
3525
3526         /* post card */
3527         if (amdgpu_device_need_post(adev)) {
3528                 r = amdgpu_atom_asic_init(adev->mode_info.atom_context);
3529                 if (r)
3530                         DRM_ERROR("amdgpu asic init failed\n");
3531         }
3532
3533         r = amdgpu_device_ip_resume(adev);
3534         if (r) {
3535                 DRM_ERROR("amdgpu_device_ip_resume failed (%d).\n", r);
3536                 return r;
3537         }
3538         amdgpu_fence_driver_resume(adev);
3539
3540
3541         r = amdgpu_device_ip_late_init(adev);
3542         if (r)
3543                 return r;
3544
3545         queue_delayed_work(system_wq, &adev->delayed_init_work,
3546                            msecs_to_jiffies(AMDGPU_RESUME_MS));
3547
3548         if (!amdgpu_device_has_dc_support(adev)) {
3549                 /* pin cursors */
3550                 list_for_each_entry(crtc, &dev->mode_config.crtc_list, head) {
3551                         struct amdgpu_crtc *amdgpu_crtc = to_amdgpu_crtc(crtc);
3552
3553                         if (amdgpu_crtc->cursor_bo && !adev->enable_virtual_display) {
3554                                 struct amdgpu_bo *aobj = gem_to_amdgpu_bo(amdgpu_crtc->cursor_bo);
3555                                 r = amdgpu_bo_reserve(aobj, true);
3556                                 if (r == 0) {
3557                                         r = amdgpu_bo_pin(aobj, AMDGPU_GEM_DOMAIN_VRAM);
3558                                         if (r != 0)
3559                                                 DRM_ERROR("Failed to pin cursor BO (%d)\n", r);
3560                                         amdgpu_crtc->cursor_addr = amdgpu_bo_gpu_offset(aobj);
3561                                         amdgpu_bo_unreserve(aobj);
3562                                 }
3563                         }
3564                 }
3565         }
3566         r = amdgpu_amdkfd_resume(adev, !fbcon);
3567         if (r)
3568                 return r;
3569
3570         /* Make sure IB tests flushed */
3571         flush_delayed_work(&adev->delayed_init_work);
3572
3573         /* blat the mode back in */
3574         if (fbcon) {
3575                 if (!amdgpu_device_has_dc_support(adev)) {
3576                         /* pre DCE11 */
3577                         drm_helper_resume_force_mode(dev);
3578
3579                         /* turn on display hw */
3580                         drm_modeset_lock_all(dev);
3581
3582                         drm_connector_list_iter_begin(dev, &iter);
3583                         drm_for_each_connector_iter(connector, &iter)
3584                                 drm_helper_connector_dpms(connector,
3585                                                           DRM_MODE_DPMS_ON);
3586                         drm_connector_list_iter_end(&iter);
3587
3588                         drm_modeset_unlock_all(dev);
3589                 }
3590                 amdgpu_fbdev_set_suspend(adev, 0);
3591         }
3592
3593         drm_kms_helper_poll_enable(dev);
3594
3595         amdgpu_ras_resume(adev);
3596
3597         /*
3598          * Most of the connector probing functions try to acquire runtime pm
3599          * refs to ensure that the GPU is powered on when connector polling is
3600          * performed. Since we're calling this from a runtime PM callback,
3601          * trying to acquire rpm refs will cause us to deadlock.
3602          *
3603          * Since we're guaranteed to be holding the rpm lock, it's safe to
3604          * temporarily disable the rpm helpers so this doesn't deadlock us.
3605          */
3606 #ifdef CONFIG_PM
3607         dev->dev->power.disable_depth++;
3608 #endif
3609         if (!amdgpu_device_has_dc_support(adev))
3610                 drm_helper_hpd_irq_event(dev);
3611         else
3612                 drm_kms_helper_hotplug_event(dev);
3613 #ifdef CONFIG_PM
3614         dev->dev->power.disable_depth--;
3615 #endif
3616         adev->in_suspend = false;
3617
3618         return 0;
3619 }
3620
3621 /**
3622  * amdgpu_device_ip_check_soft_reset - did soft reset succeed
3623  *
3624  * @adev: amdgpu_device pointer
3625  *
3626  * The list of all the hardware IPs that make up the asic is walked and
3627  * the check_soft_reset callbacks are run.  check_soft_reset determines
3628  * if the asic is still hung or not.
3629  * Returns true if any of the IPs are still in a hung state, false if not.
3630  */
3631 static bool amdgpu_device_ip_check_soft_reset(struct amdgpu_device *adev)
3632 {
3633         int i;
3634         bool asic_hang = false;
3635
3636         if (amdgpu_sriov_vf(adev))
3637                 return true;
3638
3639         if (amdgpu_asic_need_full_reset(adev))
3640                 return true;
3641
3642         for (i = 0; i < adev->num_ip_blocks; i++) {
3643                 if (!adev->ip_blocks[i].status.valid)
3644                         continue;
3645                 if (adev->ip_blocks[i].version->funcs->check_soft_reset)
3646                         adev->ip_blocks[i].status.hang =
3647                                 adev->ip_blocks[i].version->funcs->check_soft_reset(adev);
3648                 if (adev->ip_blocks[i].status.hang) {
3649                         DRM_INFO("IP block:%s is hung!\n", adev->ip_blocks[i].version->funcs->name);
3650                         asic_hang = true;
3651                 }
3652         }
3653         return asic_hang;
3654 }
3655
3656 /**
3657  * amdgpu_device_ip_pre_soft_reset - prepare for soft reset
3658  *
3659  * @adev: amdgpu_device pointer
3660  *
3661  * The list of all the hardware IPs that make up the asic is walked and the
3662  * pre_soft_reset callbacks are run if the block is hung.  pre_soft_reset
3663  * handles any IP specific hardware or software state changes that are
3664  * necessary for a soft reset to succeed.
3665  * Returns 0 on success, negative error code on failure.
3666  */
3667 static int amdgpu_device_ip_pre_soft_reset(struct amdgpu_device *adev)
3668 {
3669         int i, r = 0;
3670
3671         for (i = 0; i < adev->num_ip_blocks; i++) {
3672                 if (!adev->ip_blocks[i].status.valid)
3673                         continue;
3674                 if (adev->ip_blocks[i].status.hang &&
3675                     adev->ip_blocks[i].version->funcs->pre_soft_reset) {
3676                         r = adev->ip_blocks[i].version->funcs->pre_soft_reset(adev);
3677                         if (r)
3678                                 return r;
3679                 }
3680         }
3681
3682         return 0;
3683 }
3684
3685 /**
3686  * amdgpu_device_ip_need_full_reset - check if a full asic reset is needed
3687  *
3688  * @adev: amdgpu_device pointer
3689  *
3690  * Some hardware IPs cannot be soft reset.  If they are hung, a full gpu
3691  * reset is necessary to recover.
3692  * Returns true if a full asic reset is required, false if not.
3693  */
3694 static bool amdgpu_device_ip_need_full_reset(struct amdgpu_device *adev)
3695 {
3696         int i;
3697
3698         if (amdgpu_asic_need_full_reset(adev))
3699                 return true;
3700
3701         for (i = 0; i < adev->num_ip_blocks; i++) {
3702                 if (!adev->ip_blocks[i].status.valid)
3703                         continue;
3704                 if ((adev->ip_blocks[i].version->type == AMD_IP_BLOCK_TYPE_GMC) ||
3705                     (adev->ip_blocks[i].version->type == AMD_IP_BLOCK_TYPE_SMC) ||
3706                     (adev->ip_blocks[i].version->type == AMD_IP_BLOCK_TYPE_ACP) ||
3707                     (adev->ip_blocks[i].version->type == AMD_IP_BLOCK_TYPE_DCE) ||
3708                      adev->ip_blocks[i].version->type == AMD_IP_BLOCK_TYPE_PSP) {
3709                         if (adev->ip_blocks[i].status.hang) {
3710                                 DRM_INFO("Some block need full reset!\n");
3711                                 return true;
3712                         }
3713                 }
3714         }
3715         return false;
3716 }
3717
3718 /**
3719  * amdgpu_device_ip_soft_reset - do a soft reset
3720  *
3721  * @adev: amdgpu_device pointer
3722  *
3723  * The list of all the hardware IPs that make up the asic is walked and the
3724  * soft_reset callbacks are run if the block is hung.  soft_reset handles any
3725  * IP specific hardware or software state changes that are necessary to soft
3726  * reset the IP.
3727  * Returns 0 on success, negative error code on failure.
3728  */
3729 static int amdgpu_device_ip_soft_reset(struct amdgpu_device *adev)
3730 {
3731         int i, r = 0;
3732
3733         for (i = 0; i < adev->num_ip_blocks; i++) {
3734                 if (!adev->ip_blocks[i].status.valid)
3735                         continue;
3736                 if (adev->ip_blocks[i].status.hang &&
3737                     adev->ip_blocks[i].version->funcs->soft_reset) {
3738                         r = adev->ip_blocks[i].version->funcs->soft_reset(adev);
3739                         if (r)
3740                                 return r;
3741                 }
3742         }
3743
3744         return 0;
3745 }
3746
3747 /**
3748  * amdgpu_device_ip_post_soft_reset - clean up from soft reset
3749  *
3750  * @adev: amdgpu_device pointer
3751  *
3752  * The list of all the hardware IPs that make up the asic is walked and the
3753  * post_soft_reset callbacks are run if the asic was hung.  post_soft_reset
3754  * handles any IP specific hardware or software state changes that are
3755  * necessary after the IP has been soft reset.
3756  * Returns 0 on success, negative error code on failure.
3757  */
3758 static int amdgpu_device_ip_post_soft_reset(struct amdgpu_device *adev)
3759 {
3760         int i, r = 0;
3761
3762         for (i = 0; i < adev->num_ip_blocks; i++) {
3763                 if (!adev->ip_blocks[i].status.valid)
3764                         continue;
3765                 if (adev->ip_blocks[i].status.hang &&
3766                     adev->ip_blocks[i].version->funcs->post_soft_reset)
3767                         r = adev->ip_blocks[i].version->funcs->post_soft_reset(adev);
3768                 if (r)
3769                         return r;
3770         }
3771
3772         return 0;
3773 }
3774
3775 /**
3776  * amdgpu_device_recover_vram - Recover some VRAM contents
3777  *
3778  * @adev: amdgpu_device pointer
3779  *
3780  * Restores the contents of VRAM buffers from the shadows in GTT.  Used to
3781  * restore things like GPUVM page tables after a GPU reset where
3782  * the contents of VRAM might be lost.
3783  *
3784  * Returns:
3785  * 0 on success, negative error code on failure.
3786  */
3787 static int amdgpu_device_recover_vram(struct amdgpu_device *adev)
3788 {
3789         struct dma_fence *fence = NULL, *next = NULL;
3790         struct amdgpu_bo *shadow;
3791         long r = 1, tmo;
3792
3793         if (amdgpu_sriov_runtime(adev))
3794                 tmo = msecs_to_jiffies(8000);
3795         else
3796                 tmo = msecs_to_jiffies(100);
3797
3798         DRM_INFO("recover vram bo from shadow start\n");
3799         mutex_lock(&adev->shadow_list_lock);
3800         list_for_each_entry(shadow, &adev->shadow_list, shadow_list) {
3801
3802                 /* No need to recover an evicted BO */
3803                 if (shadow->tbo.mem.mem_type != TTM_PL_TT ||
3804                     shadow->tbo.mem.start == AMDGPU_BO_INVALID_OFFSET ||
3805                     shadow->parent->tbo.mem.mem_type != TTM_PL_VRAM)
3806                         continue;
3807
3808                 r = amdgpu_bo_restore_shadow(shadow, &next);
3809                 if (r)
3810                         break;
3811
3812                 if (fence) {
3813                         tmo = dma_fence_wait_timeout(fence, false, tmo);
3814                         dma_fence_put(fence);
3815                         fence = next;
3816                         if (tmo == 0) {
3817                                 r = -ETIMEDOUT;
3818                                 break;
3819                         } else if (tmo < 0) {
3820                                 r = tmo;
3821                                 break;
3822                         }
3823                 } else {
3824                         fence = next;
3825                 }
3826         }
3827         mutex_unlock(&adev->shadow_list_lock);
3828
3829         if (fence)
3830                 tmo = dma_fence_wait_timeout(fence, false, tmo);
3831         dma_fence_put(fence);
3832
3833         if (r < 0 || tmo <= 0) {
3834                 DRM_ERROR("recover vram bo from shadow failed, r is %ld, tmo is %ld\n", r, tmo);
3835                 return -EIO;
3836         }
3837
3838         DRM_INFO("recover vram bo from shadow done\n");
3839         return 0;
3840 }
3841
3842
3843 /**
3844  * amdgpu_device_reset_sriov - reset ASIC for SR-IOV vf
3845  *
3846  * @adev: amdgpu device pointer
3847  * @from_hypervisor: request from hypervisor
3848  *
3849  * do VF FLR and reinitialize Asic
3850  * return 0 means succeeded otherwise failed
3851  */
3852 static int amdgpu_device_reset_sriov(struct amdgpu_device *adev,
3853                                      bool from_hypervisor)
3854 {
3855         int r;
3856
3857         if (from_hypervisor)
3858                 r = amdgpu_virt_request_full_gpu(adev, true);
3859         else
3860                 r = amdgpu_virt_reset_gpu(adev);
3861         if (r)
3862                 return r;
3863
3864         amdgpu_amdkfd_pre_reset(adev);
3865
3866         /* Resume IP prior to SMC */
3867         r = amdgpu_device_ip_reinit_early_sriov(adev);
3868         if (r)
3869                 goto error;
3870
3871         amdgpu_virt_init_data_exchange(adev);
3872         /* we need recover gart prior to run SMC/CP/SDMA resume */
3873         amdgpu_gtt_mgr_recover(&adev->mman.bdev.man[TTM_PL_TT]);
3874
3875         r = amdgpu_device_fw_loading(adev);
3876         if (r)
3877                 return r;
3878
3879         /* now we are okay to resume SMC/CP/SDMA */
3880         r = amdgpu_device_ip_reinit_late_sriov(adev);
3881         if (r)
3882                 goto error;
3883
3884         amdgpu_irq_gpu_reset_resume_helper(adev);
3885         r = amdgpu_ib_ring_tests(adev);
3886         amdgpu_amdkfd_post_reset(adev);
3887
3888 error:
3889         amdgpu_virt_release_full_gpu(adev, true);
3890         if (!r && adev->virt.gim_feature & AMDGIM_FEATURE_GIM_FLR_VRAMLOST) {
3891                 amdgpu_inc_vram_lost(adev);
3892                 r = amdgpu_device_recover_vram(adev);
3893         }
3894
3895         return r;
3896 }
3897
3898 /**
3899  * amdgpu_device_should_recover_gpu - check if we should try GPU recovery
3900  *
3901  * @adev: amdgpu device pointer
3902  *
3903  * Check amdgpu_gpu_recovery and SRIOV status to see if we should try to recover
3904  * a hung GPU.
3905  */
3906 bool amdgpu_device_should_recover_gpu(struct amdgpu_device *adev)
3907 {
3908         if (!amdgpu_device_ip_check_soft_reset(adev)) {
3909                 DRM_INFO("Timeout, but no hardware hang detected.\n");
3910                 return false;
3911         }
3912
3913         if (amdgpu_gpu_recovery == 0)
3914                 goto disabled;
3915
3916         if (amdgpu_sriov_vf(adev))
3917                 return true;
3918
3919         if (amdgpu_gpu_recovery == -1) {
3920                 switch (adev->asic_type) {
3921                 case CHIP_BONAIRE:
3922                 case CHIP_HAWAII:
3923                 case CHIP_TOPAZ:
3924                 case CHIP_TONGA:
3925                 case CHIP_FIJI:
3926                 case CHIP_POLARIS10:
3927                 case CHIP_POLARIS11:
3928                 case CHIP_POLARIS12:
3929                 case CHIP_VEGAM:
3930                 case CHIP_VEGA20:
3931                 case CHIP_VEGA10:
3932                 case CHIP_VEGA12:
3933                 case CHIP_RAVEN:
3934                 case CHIP_ARCTURUS:
3935                 case CHIP_RENOIR:
3936                 case CHIP_NAVI10:
3937                 case CHIP_NAVI14:
3938                 case CHIP_NAVI12:
3939                         break;
3940                 default:
3941                         goto disabled;
3942                 }
3943         }
3944
3945         return true;
3946
3947 disabled:
3948                 DRM_INFO("GPU recovery disabled.\n");
3949                 return false;
3950 }
3951
3952
3953 static int amdgpu_device_pre_asic_reset(struct amdgpu_device *adev,
3954                                         struct amdgpu_job *job,
3955                                         bool *need_full_reset_arg)
3956 {
3957         int i, r = 0;
3958         bool need_full_reset  = *need_full_reset_arg;
3959
3960         amdgpu_debugfs_wait_dump(adev);
3961
3962         /* block all schedulers and reset given job's ring */
3963         for (i = 0; i < AMDGPU_MAX_RINGS; ++i) {
3964                 struct amdgpu_ring *ring = adev->rings[i];
3965
3966                 if (!ring || !ring->sched.thread)
3967                         continue;
3968
3969                 /* after all hw jobs are reset, hw fence is meaningless, so force_completion */
3970                 amdgpu_fence_driver_force_completion(ring);
3971         }
3972
3973         if(job)
3974                 drm_sched_increase_karma(&job->base);
3975
3976         /* Don't suspend on bare metal if we are not going to HW reset the ASIC */
3977         if (!amdgpu_sriov_vf(adev)) {
3978
3979                 if (!need_full_reset)
3980                         need_full_reset = amdgpu_device_ip_need_full_reset(adev);
3981
3982                 if (!need_full_reset) {
3983                         amdgpu_device_ip_pre_soft_reset(adev);
3984                         r = amdgpu_device_ip_soft_reset(adev);
3985                         amdgpu_device_ip_post_soft_reset(adev);
3986                         if (r || amdgpu_device_ip_check_soft_reset(adev)) {
3987                                 DRM_INFO("soft reset failed, will fallback to full reset!\n");
3988                                 need_full_reset = true;
3989                         }
3990                 }
3991
3992                 if (need_full_reset)
3993                         r = amdgpu_device_ip_suspend(adev);
3994
3995                 *need_full_reset_arg = need_full_reset;
3996         }
3997
3998         return r;
3999 }
4000
4001 static int amdgpu_do_asic_reset(struct amdgpu_hive_info *hive,
4002                                struct list_head *device_list_handle,
4003                                bool *need_full_reset_arg)
4004 {
4005         struct amdgpu_device *tmp_adev = NULL;
4006         bool need_full_reset = *need_full_reset_arg, vram_lost = false;
4007         int r = 0;
4008
4009         /*
4010          * ASIC reset has to be done on all HGMI hive nodes ASAP
4011          * to allow proper links negotiation in FW (within 1 sec)
4012          */
4013         if (need_full_reset) {
4014                 list_for_each_entry(tmp_adev, device_list_handle, gmc.xgmi.head) {
4015                         /* For XGMI run all resets in parallel to speed up the process */
4016                         if (tmp_adev->gmc.xgmi.num_physical_nodes > 1) {
4017                                 if (!queue_work(system_unbound_wq, &tmp_adev->xgmi_reset_work))
4018                                         r = -EALREADY;
4019                         } else
4020                                 r = amdgpu_asic_reset(tmp_adev);
4021
4022                         if (r) {
4023                                 DRM_ERROR("ASIC reset failed with error, %d for drm dev, %s",
4024                                          r, tmp_adev->ddev->unique);
4025                                 break;
4026                         }
4027                 }
4028
4029                 /* For XGMI wait for all resets to complete before proceed */
4030                 if (!r) {
4031                         list_for_each_entry(tmp_adev, device_list_handle,
4032                                             gmc.xgmi.head) {
4033                                 if (tmp_adev->gmc.xgmi.num_physical_nodes > 1) {
4034                                         flush_work(&tmp_adev->xgmi_reset_work);
4035                                         r = tmp_adev->asic_reset_res;
4036                                         if (r)
4037                                                 break;
4038                                 }
4039                         }
4040                 }
4041         }
4042
4043         if (!r && amdgpu_ras_intr_triggered()) {
4044                 list_for_each_entry(tmp_adev, device_list_handle, gmc.xgmi.head) {
4045                         if (tmp_adev->mmhub.funcs &&
4046                             tmp_adev->mmhub.funcs->reset_ras_error_count)
4047                                 tmp_adev->mmhub.funcs->reset_ras_error_count(tmp_adev);
4048                 }
4049
4050                 amdgpu_ras_intr_cleared();
4051         }
4052
4053         list_for_each_entry(tmp_adev, device_list_handle, gmc.xgmi.head) {
4054                 if (need_full_reset) {
4055                         /* post card */
4056                         if (amdgpu_atom_asic_init(tmp_adev->mode_info.atom_context))
4057                                 DRM_WARN("asic atom init failed!");
4058
4059                         if (!r) {
4060                                 dev_info(tmp_adev->dev, "GPU reset succeeded, trying to resume\n");
4061                                 r = amdgpu_device_ip_resume_phase1(tmp_adev);
4062                                 if (r)
4063                                         goto out;
4064
4065                                 vram_lost = amdgpu_device_check_vram_lost(tmp_adev);
4066                                 if (vram_lost) {
4067                                         DRM_INFO("VRAM is lost due to GPU reset!\n");
4068                                         amdgpu_inc_vram_lost(tmp_adev);
4069                                 }
4070
4071                                 r = amdgpu_gtt_mgr_recover(
4072                                         &tmp_adev->mman.bdev.man[TTM_PL_TT]);
4073                                 if (r)
4074                                         goto out;
4075
4076                                 r = amdgpu_device_fw_loading(tmp_adev);
4077                                 if (r)
4078                                         return r;
4079
4080                                 r = amdgpu_device_ip_resume_phase2(tmp_adev);
4081                                 if (r)
4082                                         goto out;
4083
4084                                 if (vram_lost)
4085                                         amdgpu_device_fill_reset_magic(tmp_adev);
4086
4087                                 /*
4088                                  * Add this ASIC as tracked as reset was already
4089                                  * complete successfully.
4090                                  */
4091                                 amdgpu_register_gpu_instance(tmp_adev);
4092
4093                                 r = amdgpu_device_ip_late_init(tmp_adev);
4094                                 if (r)
4095                                         goto out;
4096
4097                                 amdgpu_fbdev_set_suspend(tmp_adev, 0);
4098
4099                                 /* must succeed. */
4100                                 amdgpu_ras_resume(tmp_adev);
4101
4102                                 /* Update PSP FW topology after reset */
4103                                 if (hive && tmp_adev->gmc.xgmi.num_physical_nodes > 1)
4104                                         r = amdgpu_xgmi_update_topology(hive, tmp_adev);
4105                         }
4106                 }
4107
4108
4109 out:
4110                 if (!r) {
4111                         amdgpu_irq_gpu_reset_resume_helper(tmp_adev);
4112                         r = amdgpu_ib_ring_tests(tmp_adev);
4113                         if (r) {
4114                                 dev_err(tmp_adev->dev, "ib ring test failed (%d).\n", r);
4115                                 r = amdgpu_device_ip_suspend(tmp_adev);
4116                                 need_full_reset = true;
4117                                 r = -EAGAIN;
4118                                 goto end;
4119                         }
4120                 }
4121
4122                 if (!r)
4123                         r = amdgpu_device_recover_vram(tmp_adev);
4124                 else
4125                         tmp_adev->asic_reset_res = r;
4126         }
4127
4128 end:
4129         *need_full_reset_arg = need_full_reset;
4130         return r;
4131 }
4132
4133 static bool amdgpu_device_lock_adev(struct amdgpu_device *adev, bool trylock)
4134 {
4135         if (trylock) {
4136                 if (!mutex_trylock(&adev->lock_reset))
4137                         return false;
4138         } else
4139                 mutex_lock(&adev->lock_reset);
4140
4141         atomic_inc(&adev->gpu_reset_counter);
4142         adev->in_gpu_reset = true;
4143         switch (amdgpu_asic_reset_method(adev)) {
4144         case AMD_RESET_METHOD_MODE1:
4145                 adev->mp1_state = PP_MP1_STATE_SHUTDOWN;
4146                 break;
4147         case AMD_RESET_METHOD_MODE2:
4148                 adev->mp1_state = PP_MP1_STATE_RESET;
4149                 break;
4150         default:
4151                 adev->mp1_state = PP_MP1_STATE_NONE;
4152                 break;
4153         }
4154
4155         return true;
4156 }
4157
4158 static void amdgpu_device_unlock_adev(struct amdgpu_device *adev)
4159 {
4160         amdgpu_vf_error_trans_all(adev);
4161         adev->mp1_state = PP_MP1_STATE_NONE;
4162         adev->in_gpu_reset = false;
4163         mutex_unlock(&adev->lock_reset);
4164 }
4165
4166 static void amdgpu_device_resume_display_audio(struct amdgpu_device *adev)
4167 {
4168         struct pci_dev *p = NULL;
4169
4170         p = pci_get_domain_bus_and_slot(pci_domain_nr(adev->pdev->bus),
4171                         adev->pdev->bus->number, 1);
4172         if (p) {
4173                 pm_runtime_enable(&(p->dev));
4174                 pm_runtime_resume(&(p->dev));
4175         }
4176 }
4177
4178 static int amdgpu_device_suspend_display_audio(struct amdgpu_device *adev)
4179 {
4180         enum amd_reset_method reset_method;
4181         struct pci_dev *p = NULL;
4182         u64 expires;
4183
4184         /*
4185          * For now, only BACO and mode1 reset are confirmed
4186          * to suffer the audio issue without proper suspended.
4187          */
4188         reset_method = amdgpu_asic_reset_method(adev);
4189         if ((reset_method != AMD_RESET_METHOD_BACO) &&
4190              (reset_method != AMD_RESET_METHOD_MODE1))
4191                 return -EINVAL;
4192
4193         p = pci_get_domain_bus_and_slot(pci_domain_nr(adev->pdev->bus),
4194                         adev->pdev->bus->number, 1);
4195         if (!p)
4196                 return -ENODEV;
4197
4198         expires = pm_runtime_autosuspend_expiration(&(p->dev));
4199         if (!expires)
4200                 /*
4201                  * If we cannot get the audio device autosuspend delay,
4202                  * a fixed 4S interval will be used. Considering 3S is
4203                  * the audio controller default autosuspend delay setting.
4204                  * 4S used here is guaranteed to cover that.
4205                  */
4206                 expires = ktime_get_mono_fast_ns() + NSEC_PER_SEC * 4ULL;
4207
4208         while (!pm_runtime_status_suspended(&(p->dev))) {
4209                 if (!pm_runtime_suspend(&(p->dev)))
4210                         break;
4211
4212                 if (expires < ktime_get_mono_fast_ns()) {
4213                         dev_warn(adev->dev, "failed to suspend display audio\n");
4214                         /* TODO: abort the succeeding gpu reset? */
4215                         return -ETIMEDOUT;
4216                 }
4217         }
4218
4219         pm_runtime_disable(&(p->dev));
4220
4221         return 0;
4222 }
4223
4224 /**
4225  * amdgpu_device_gpu_recover - reset the asic and recover scheduler
4226  *
4227  * @adev: amdgpu device pointer
4228  * @job: which job trigger hang
4229  *
4230  * Attempt to reset the GPU if it has hung (all asics).
4231  * Attempt to do soft-reset or full-reset and reinitialize Asic
4232  * Returns 0 for success or an error on failure.
4233  */
4234
4235 int amdgpu_device_gpu_recover(struct amdgpu_device *adev,
4236                               struct amdgpu_job *job)
4237 {
4238         struct list_head device_list, *device_list_handle =  NULL;
4239         bool need_full_reset = false;
4240         bool job_signaled = false;
4241         struct amdgpu_hive_info *hive = NULL;
4242         struct amdgpu_device *tmp_adev = NULL;
4243         int i, r = 0;
4244         bool in_ras_intr = amdgpu_ras_intr_triggered();
4245         bool use_baco =
4246                 (amdgpu_asic_reset_method(adev) == AMD_RESET_METHOD_BACO) ?
4247                 true : false;
4248         bool audio_suspended = false;
4249
4250         /*
4251          * Flush RAM to disk so that after reboot
4252          * the user can read log and see why the system rebooted.
4253          */
4254         if (in_ras_intr && !use_baco && amdgpu_ras_get_context(adev)->reboot) {
4255
4256                 DRM_WARN("Emergency reboot.");
4257
4258                 ksys_sync_helper();
4259                 emergency_restart();
4260         }
4261
4262         dev_info(adev->dev, "GPU %s begin!\n",
4263                 (in_ras_intr && !use_baco) ? "jobs stop":"reset");
4264
4265         /*
4266          * Here we trylock to avoid chain of resets executing from
4267          * either trigger by jobs on different adevs in XGMI hive or jobs on
4268          * different schedulers for same device while this TO handler is running.
4269          * We always reset all schedulers for device and all devices for XGMI
4270          * hive so that should take care of them too.
4271          */
4272         hive = amdgpu_get_xgmi_hive(adev, true);
4273         if (hive && !mutex_trylock(&hive->reset_lock)) {
4274                 DRM_INFO("Bailing on TDR for s_job:%llx, hive: %llx as another already in progress",
4275                           job ? job->base.id : -1, hive->hive_id);
4276                 mutex_unlock(&hive->hive_lock);
4277                 return 0;
4278         }
4279
4280         /*
4281          * Build list of devices to reset.
4282          * In case we are in XGMI hive mode, resort the device list
4283          * to put adev in the 1st position.
4284          */
4285         INIT_LIST_HEAD(&device_list);
4286         if (adev->gmc.xgmi.num_physical_nodes > 1) {
4287                 if (!hive)
4288                         return -ENODEV;
4289                 if (!list_is_first(&adev->gmc.xgmi.head, &hive->device_list))
4290                         list_rotate_to_front(&adev->gmc.xgmi.head, &hive->device_list);
4291                 device_list_handle = &hive->device_list;
4292         } else {
4293                 list_add_tail(&adev->gmc.xgmi.head, &device_list);
4294                 device_list_handle = &device_list;
4295         }
4296
4297         /* block all schedulers and reset given job's ring */
4298         list_for_each_entry(tmp_adev, device_list_handle, gmc.xgmi.head) {
4299                 if (!amdgpu_device_lock_adev(tmp_adev, !hive)) {
4300                         DRM_INFO("Bailing on TDR for s_job:%llx, as another already in progress",
4301                                   job ? job->base.id : -1);
4302                         mutex_unlock(&hive->hive_lock);
4303                         return 0;
4304                 }
4305
4306                 /*
4307                  * Try to put the audio codec into suspend state
4308                  * before gpu reset started.
4309                  *
4310                  * Due to the power domain of the graphics device
4311                  * is shared with AZ power domain. Without this,
4312                  * we may change the audio hardware from behind
4313                  * the audio driver's back. That will trigger
4314                  * some audio codec errors.
4315                  */
4316                 if (!amdgpu_device_suspend_display_audio(tmp_adev))
4317                         audio_suspended = true;
4318
4319                 amdgpu_ras_set_error_query_ready(tmp_adev, false);
4320
4321                 cancel_delayed_work_sync(&tmp_adev->delayed_init_work);
4322
4323                 if (!amdgpu_sriov_vf(tmp_adev))
4324                         amdgpu_amdkfd_pre_reset(tmp_adev);
4325
4326                 /*
4327                  * Mark these ASICs to be reseted as untracked first
4328                  * And add them back after reset completed
4329                  */
4330                 amdgpu_unregister_gpu_instance(tmp_adev);
4331
4332                 amdgpu_fbdev_set_suspend(tmp_adev, 1);
4333
4334                 /* disable ras on ALL IPs */
4335                 if (!(in_ras_intr && !use_baco) &&
4336                       amdgpu_device_ip_need_full_reset(tmp_adev))
4337                         amdgpu_ras_suspend(tmp_adev);
4338
4339                 for (i = 0; i < AMDGPU_MAX_RINGS; ++i) {
4340                         struct amdgpu_ring *ring = tmp_adev->rings[i];
4341
4342                         if (!ring || !ring->sched.thread)
4343                                 continue;
4344
4345                         drm_sched_stop(&ring->sched, job ? &job->base : NULL);
4346
4347                         if (in_ras_intr && !use_baco)
4348                                 amdgpu_job_stop_all_jobs_on_sched(&ring->sched);
4349                 }
4350         }
4351
4352         if (in_ras_intr && !use_baco)
4353                 goto skip_sched_resume;
4354
4355         /*
4356          * Must check guilty signal here since after this point all old
4357          * HW fences are force signaled.
4358          *
4359          * job->base holds a reference to parent fence
4360          */
4361         if (job && job->base.s_fence->parent &&
4362             dma_fence_is_signaled(job->base.s_fence->parent)) {
4363                 job_signaled = true;
4364                 dev_info(adev->dev, "Guilty job already signaled, skipping HW reset");
4365                 goto skip_hw_reset;
4366         }
4367
4368 retry:  /* Rest of adevs pre asic reset from XGMI hive. */
4369         list_for_each_entry(tmp_adev, device_list_handle, gmc.xgmi.head) {
4370                 r = amdgpu_device_pre_asic_reset(tmp_adev,
4371                                                  NULL,
4372                                                  &need_full_reset);
4373                 /*TODO Should we stop ?*/
4374                 if (r) {
4375                         DRM_ERROR("GPU pre asic reset failed with err, %d for drm dev, %s ",
4376                                   r, tmp_adev->ddev->unique);
4377                         tmp_adev->asic_reset_res = r;
4378                 }
4379         }
4380
4381         /* Actual ASIC resets if needed.*/
4382         /* TODO Implement XGMI hive reset logic for SRIOV */
4383         if (amdgpu_sriov_vf(adev)) {
4384                 r = amdgpu_device_reset_sriov(adev, job ? false : true);
4385                 if (r)
4386                         adev->asic_reset_res = r;
4387         } else {
4388                 r  = amdgpu_do_asic_reset(hive, device_list_handle, &need_full_reset);
4389                 if (r && r == -EAGAIN)
4390                         goto retry;
4391         }
4392
4393 skip_hw_reset:
4394
4395         /* Post ASIC reset for all devs .*/
4396         list_for_each_entry(tmp_adev, device_list_handle, gmc.xgmi.head) {
4397
4398                 for (i = 0; i < AMDGPU_MAX_RINGS; ++i) {
4399                         struct amdgpu_ring *ring = tmp_adev->rings[i];
4400
4401                         if (!ring || !ring->sched.thread)
4402                                 continue;
4403
4404                         /* No point to resubmit jobs if we didn't HW reset*/
4405                         if (!tmp_adev->asic_reset_res && !job_signaled)
4406                                 drm_sched_resubmit_jobs(&ring->sched);
4407
4408                         drm_sched_start(&ring->sched, !tmp_adev->asic_reset_res);
4409                 }
4410
4411                 if (!amdgpu_device_has_dc_support(tmp_adev) && !job_signaled) {
4412                         drm_helper_resume_force_mode(tmp_adev->ddev);
4413                 }
4414
4415                 tmp_adev->asic_reset_res = 0;
4416
4417                 if (r) {
4418                         /* bad news, how to tell it to userspace ? */
4419                         dev_info(tmp_adev->dev, "GPU reset(%d) failed\n", atomic_read(&tmp_adev->gpu_reset_counter));
4420                         amdgpu_vf_error_put(tmp_adev, AMDGIM_ERROR_VF_GPU_RESET_FAIL, 0, r);
4421                 } else {
4422                         dev_info(tmp_adev->dev, "GPU reset(%d) succeeded!\n", atomic_read(&tmp_adev->gpu_reset_counter));
4423                 }
4424         }
4425
4426 skip_sched_resume:
4427         list_for_each_entry(tmp_adev, device_list_handle, gmc.xgmi.head) {
4428                 /*unlock kfd: SRIOV would do it separately */
4429                 if (!(in_ras_intr && !use_baco) && !amdgpu_sriov_vf(tmp_adev))
4430                         amdgpu_amdkfd_post_reset(tmp_adev);
4431                 if (audio_suspended)
4432                         amdgpu_device_resume_display_audio(tmp_adev);
4433                 amdgpu_device_unlock_adev(tmp_adev);
4434         }
4435
4436         if (hive) {
4437                 mutex_unlock(&hive->reset_lock);
4438                 mutex_unlock(&hive->hive_lock);
4439         }
4440
4441         if (r)
4442                 dev_info(adev->dev, "GPU reset end with ret = %d\n", r);
4443         return r;
4444 }
4445
4446 /**
4447  * amdgpu_device_get_pcie_info - fence pcie info about the PCIE slot
4448  *
4449  * @adev: amdgpu_device pointer
4450  *
4451  * Fetchs and stores in the driver the PCIE capabilities (gen speed
4452  * and lanes) of the slot the device is in. Handles APUs and
4453  * virtualized environments where PCIE config space may not be available.
4454  */
4455 static void amdgpu_device_get_pcie_info(struct amdgpu_device *adev)
4456 {
4457         struct pci_dev *pdev;
4458         enum pci_bus_speed speed_cap, platform_speed_cap;
4459         enum pcie_link_width platform_link_width;
4460
4461         if (amdgpu_pcie_gen_cap)
4462                 adev->pm.pcie_gen_mask = amdgpu_pcie_gen_cap;
4463
4464         if (amdgpu_pcie_lane_cap)
4465                 adev->pm.pcie_mlw_mask = amdgpu_pcie_lane_cap;
4466
4467         /* covers APUs as well */
4468         if (pci_is_root_bus(adev->pdev->bus)) {
4469                 if (adev->pm.pcie_gen_mask == 0)
4470                         adev->pm.pcie_gen_mask = AMDGPU_DEFAULT_PCIE_GEN_MASK;
4471                 if (adev->pm.pcie_mlw_mask == 0)
4472                         adev->pm.pcie_mlw_mask = AMDGPU_DEFAULT_PCIE_MLW_MASK;
4473                 return;
4474         }
4475
4476         if (adev->pm.pcie_gen_mask && adev->pm.pcie_mlw_mask)
4477                 return;
4478
4479         pcie_bandwidth_available(adev->pdev, NULL,
4480                                  &platform_speed_cap, &platform_link_width);
4481
4482         if (adev->pm.pcie_gen_mask == 0) {
4483                 /* asic caps */
4484                 pdev = adev->pdev;
4485                 speed_cap = pcie_get_speed_cap(pdev);
4486                 if (speed_cap == PCI_SPEED_UNKNOWN) {
4487                         adev->pm.pcie_gen_mask |= (CAIL_ASIC_PCIE_LINK_SPEED_SUPPORT_GEN1 |
4488                                                   CAIL_ASIC_PCIE_LINK_SPEED_SUPPORT_GEN2 |
4489                                                   CAIL_ASIC_PCIE_LINK_SPEED_SUPPORT_GEN3);
4490                 } else {
4491                         if (speed_cap == PCIE_SPEED_16_0GT)
4492                                 adev->pm.pcie_gen_mask |= (CAIL_ASIC_PCIE_LINK_SPEED_SUPPORT_GEN1 |
4493                                                           CAIL_ASIC_PCIE_LINK_SPEED_SUPPORT_GEN2 |
4494                                                           CAIL_ASIC_PCIE_LINK_SPEED_SUPPORT_GEN3 |
4495                                                           CAIL_ASIC_PCIE_LINK_SPEED_SUPPORT_GEN4);
4496                         else if (speed_cap == PCIE_SPEED_8_0GT)
4497                                 adev->pm.pcie_gen_mask |= (CAIL_ASIC_PCIE_LINK_SPEED_SUPPORT_GEN1 |
4498                                                           CAIL_ASIC_PCIE_LINK_SPEED_SUPPORT_GEN2 |
4499                                                           CAIL_ASIC_PCIE_LINK_SPEED_SUPPORT_GEN3);
4500                         else if (speed_cap == PCIE_SPEED_5_0GT)
4501                                 adev->pm.pcie_gen_mask |= (CAIL_ASIC_PCIE_LINK_SPEED_SUPPORT_GEN1 |
4502                                                           CAIL_ASIC_PCIE_LINK_SPEED_SUPPORT_GEN2);
4503                         else
4504                                 adev->pm.pcie_gen_mask |= CAIL_ASIC_PCIE_LINK_SPEED_SUPPORT_GEN1;
4505                 }
4506                 /* platform caps */
4507                 if (platform_speed_cap == PCI_SPEED_UNKNOWN) {
4508                         adev->pm.pcie_gen_mask |= (CAIL_PCIE_LINK_SPEED_SUPPORT_GEN1 |
4509                                                    CAIL_PCIE_LINK_SPEED_SUPPORT_GEN2);
4510                 } else {
4511                         if (platform_speed_cap == PCIE_SPEED_16_0GT)
4512                                 adev->pm.pcie_gen_mask |= (CAIL_PCIE_LINK_SPEED_SUPPORT_GEN1 |
4513                                                            CAIL_PCIE_LINK_SPEED_SUPPORT_GEN2 |
4514                                                            CAIL_PCIE_LINK_SPEED_SUPPORT_GEN3 |
4515                                                            CAIL_PCIE_LINK_SPEED_SUPPORT_GEN4);
4516                         else if (platform_speed_cap == PCIE_SPEED_8_0GT)
4517                                 adev->pm.pcie_gen_mask |= (CAIL_PCIE_LINK_SPEED_SUPPORT_GEN1 |
4518                                                            CAIL_PCIE_LINK_SPEED_SUPPORT_GEN2 |
4519                                                            CAIL_PCIE_LINK_SPEED_SUPPORT_GEN3);
4520                         else if (platform_speed_cap == PCIE_SPEED_5_0GT)
4521                                 adev->pm.pcie_gen_mask |= (CAIL_PCIE_LINK_SPEED_SUPPORT_GEN1 |
4522                                                            CAIL_PCIE_LINK_SPEED_SUPPORT_GEN2);
4523                         else
4524                                 adev->pm.pcie_gen_mask |= CAIL_PCIE_LINK_SPEED_SUPPORT_GEN1;
4525
4526                 }
4527         }
4528         if (adev->pm.pcie_mlw_mask == 0) {
4529                 if (platform_link_width == PCIE_LNK_WIDTH_UNKNOWN) {
4530                         adev->pm.pcie_mlw_mask |= AMDGPU_DEFAULT_PCIE_MLW_MASK;
4531                 } else {
4532                         switch (platform_link_width) {
4533                         case PCIE_LNK_X32:
4534                                 adev->pm.pcie_mlw_mask = (CAIL_PCIE_LINK_WIDTH_SUPPORT_X32 |
4535                                                           CAIL_PCIE_LINK_WIDTH_SUPPORT_X16 |
4536                                                           CAIL_PCIE_LINK_WIDTH_SUPPORT_X12 |
4537                                                           CAIL_PCIE_LINK_WIDTH_SUPPORT_X8 |
4538                                                           CAIL_PCIE_LINK_WIDTH_SUPPORT_X4 |
4539                                                           CAIL_PCIE_LINK_WIDTH_SUPPORT_X2 |
4540                                                           CAIL_PCIE_LINK_WIDTH_SUPPORT_X1);
4541                                 break;
4542                         case PCIE_LNK_X16:
4543                                 adev->pm.pcie_mlw_mask = (CAIL_PCIE_LINK_WIDTH_SUPPORT_X16 |
4544                                                           CAIL_PCIE_LINK_WIDTH_SUPPORT_X12 |
4545                                                           CAIL_PCIE_LINK_WIDTH_SUPPORT_X8 |
4546                                                           CAIL_PCIE_LINK_WIDTH_SUPPORT_X4 |
4547                                                           CAIL_PCIE_LINK_WIDTH_SUPPORT_X2 |
4548                                                           CAIL_PCIE_LINK_WIDTH_SUPPORT_X1);
4549                                 break;
4550                         case PCIE_LNK_X12:
4551                                 adev->pm.pcie_mlw_mask = (CAIL_PCIE_LINK_WIDTH_SUPPORT_X12 |
4552                                                           CAIL_PCIE_LINK_WIDTH_SUPPORT_X8 |
4553                                                           CAIL_PCIE_LINK_WIDTH_SUPPORT_X4 |
4554                                                           CAIL_PCIE_LINK_WIDTH_SUPPORT_X2 |
4555                                                           CAIL_PCIE_LINK_WIDTH_SUPPORT_X1);
4556                                 break;
4557                         case PCIE_LNK_X8:
4558                                 adev->pm.pcie_mlw_mask = (CAIL_PCIE_LINK_WIDTH_SUPPORT_X8 |
4559                                                           CAIL_PCIE_LINK_WIDTH_SUPPORT_X4 |
4560                                                           CAIL_PCIE_LINK_WIDTH_SUPPORT_X2 |
4561                                                           CAIL_PCIE_LINK_WIDTH_SUPPORT_X1);
4562                                 break;
4563                         case PCIE_LNK_X4:
4564                                 adev->pm.pcie_mlw_mask = (CAIL_PCIE_LINK_WIDTH_SUPPORT_X4 |
4565                                                           CAIL_PCIE_LINK_WIDTH_SUPPORT_X2 |
4566                                                           CAIL_PCIE_LINK_WIDTH_SUPPORT_X1);
4567                                 break;
4568                         case PCIE_LNK_X2:
4569                                 adev->pm.pcie_mlw_mask = (CAIL_PCIE_LINK_WIDTH_SUPPORT_X2 |
4570                                                           CAIL_PCIE_LINK_WIDTH_SUPPORT_X1);
4571                                 break;
4572                         case PCIE_LNK_X1:
4573                                 adev->pm.pcie_mlw_mask = CAIL_PCIE_LINK_WIDTH_SUPPORT_X1;
4574                                 break;
4575                         default:
4576                                 break;
4577                         }
4578                 }
4579         }
4580 }
4581
4582 int amdgpu_device_baco_enter(struct drm_device *dev)
4583 {
4584         struct amdgpu_device *adev = dev->dev_private;
4585         struct amdgpu_ras *ras = amdgpu_ras_get_context(adev);
4586
4587         if (!amdgpu_device_supports_baco(adev->ddev))
4588                 return -ENOTSUPP;
4589
4590         if (ras && ras->supported)
4591                 adev->nbio.funcs->enable_doorbell_interrupt(adev, false);
4592
4593         return amdgpu_dpm_baco_enter(adev);
4594 }
4595
4596 int amdgpu_device_baco_exit(struct drm_device *dev)
4597 {
4598         struct amdgpu_device *adev = dev->dev_private;
4599         struct amdgpu_ras *ras = amdgpu_ras_get_context(adev);
4600         int ret = 0;
4601
4602         if (!amdgpu_device_supports_baco(adev->ddev))
4603                 return -ENOTSUPP;
4604
4605         ret = amdgpu_dpm_baco_exit(adev);
4606         if (ret)
4607                 return ret;
4608
4609         if (ras && ras->supported)
4610                 adev->nbio.funcs->enable_doorbell_interrupt(adev, true);
4611
4612         return 0;
4613 }
This page took 0.304776 seconds and 4 git commands to generate.