xref: /linux/drivers/gpu/drm/amd/amdgpu/amdgpu_device.c (revision 94901b7a74d82bfd30420f1d9d00898278fdc8bf)
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 
29 #include <linux/aperture.h>
30 #include <linux/power_supply.h>
31 #include <linux/kthread.h>
32 #include <linux/module.h>
33 #include <linux/console.h>
34 #include <linux/slab.h>
35 #include <linux/iommu.h>
36 #include <linux/pci.h>
37 #include <linux/pci-p2pdma.h>
38 #include <linux/apple-gmux.h>
39 
40 #include <drm/drm_atomic_helper.h>
41 #include <drm/drm_client_event.h>
42 #include <drm/drm_crtc_helper.h>
43 #include <drm/drm_probe_helper.h>
44 #include <drm/amdgpu_drm.h>
45 #include <linux/device.h>
46 #include <linux/vgaarb.h>
47 #include <linux/vga_switcheroo.h>
48 #include <linux/efi.h>
49 #include "amdgpu.h"
50 #include "amdgpu_trace.h"
51 #include "amdgpu_i2c.h"
52 #include "atom.h"
53 #include "amdgpu_atombios.h"
54 #include "amdgpu_atomfirmware.h"
55 #include "amd_pcie.h"
56 #ifdef CONFIG_DRM_AMDGPU_SI
57 #include "si.h"
58 #endif
59 #ifdef CONFIG_DRM_AMDGPU_CIK
60 #include "cik.h"
61 #endif
62 #include "vi.h"
63 #include "soc15.h"
64 #include "nv.h"
65 #include "bif/bif_4_1_d.h"
66 #include <linux/firmware.h>
67 #include "amdgpu_vf_error.h"
68 
69 #include "amdgpu_amdkfd.h"
70 #include "amdgpu_pm.h"
71 
72 #include "amdgpu_xgmi.h"
73 #include "amdgpu_ras.h"
74 #include "amdgpu_pmu.h"
75 #include "amdgpu_fru_eeprom.h"
76 #include "amdgpu_reset.h"
77 #include "amdgpu_virt.h"
78 #include "amdgpu_dev_coredump.h"
79 
80 #include <linux/suspend.h>
81 #include <drm/task_barrier.h>
82 #include <linux/pm_runtime.h>
83 
84 #include <drm/drm_drv.h>
85 
86 #if IS_ENABLED(CONFIG_X86)
87 #include <asm/intel-family.h>
88 #endif
89 
90 MODULE_FIRMWARE("amdgpu/vega10_gpu_info.bin");
91 MODULE_FIRMWARE("amdgpu/vega12_gpu_info.bin");
92 MODULE_FIRMWARE("amdgpu/raven_gpu_info.bin");
93 MODULE_FIRMWARE("amdgpu/picasso_gpu_info.bin");
94 MODULE_FIRMWARE("amdgpu/raven2_gpu_info.bin");
95 MODULE_FIRMWARE("amdgpu/arcturus_gpu_info.bin");
96 MODULE_FIRMWARE("amdgpu/navi12_gpu_info.bin");
97 
98 #define AMDGPU_RESUME_MS		2000
99 #define AMDGPU_MAX_RETRY_LIMIT		2
100 #define AMDGPU_RETRY_SRIOV_RESET(r) ((r) == -EBUSY || (r) == -ETIMEDOUT || (r) == -EINVAL)
101 #define AMDGPU_PCIE_INDEX_FALLBACK (0x38 >> 2)
102 #define AMDGPU_PCIE_INDEX_HI_FALLBACK (0x44 >> 2)
103 #define AMDGPU_PCIE_DATA_FALLBACK (0x3C >> 2)
104 
105 static const struct drm_driver amdgpu_kms_driver;
106 
107 const char *amdgpu_asic_name[] = {
108 	"TAHITI",
109 	"PITCAIRN",
110 	"VERDE",
111 	"OLAND",
112 	"HAINAN",
113 	"BONAIRE",
114 	"KAVERI",
115 	"KABINI",
116 	"HAWAII",
117 	"MULLINS",
118 	"TOPAZ",
119 	"TONGA",
120 	"FIJI",
121 	"CARRIZO",
122 	"STONEY",
123 	"POLARIS10",
124 	"POLARIS11",
125 	"POLARIS12",
126 	"VEGAM",
127 	"VEGA10",
128 	"VEGA12",
129 	"VEGA20",
130 	"RAVEN",
131 	"ARCTURUS",
132 	"RENOIR",
133 	"ALDEBARAN",
134 	"NAVI10",
135 	"CYAN_SKILLFISH",
136 	"NAVI14",
137 	"NAVI12",
138 	"SIENNA_CICHLID",
139 	"NAVY_FLOUNDER",
140 	"VANGOGH",
141 	"DIMGREY_CAVEFISH",
142 	"BEIGE_GOBY",
143 	"YELLOW_CARP",
144 	"IP DISCOVERY",
145 	"LAST",
146 };
147 
148 #define AMDGPU_IP_BLK_MASK_ALL GENMASK(AMDGPU_MAX_IP_NUM, 0)
149 /*
150  * Default init level where all blocks are expected to be initialized. This is
151  * the level of initialization expected by default and also after a full reset
152  * of the device.
153  */
154 struct amdgpu_init_level amdgpu_init_default = {
155 	.level = AMDGPU_INIT_LEVEL_DEFAULT,
156 	.hwini_ip_block_mask = AMDGPU_IP_BLK_MASK_ALL,
157 };
158 
159 struct amdgpu_init_level amdgpu_init_recovery = {
160 	.level = AMDGPU_INIT_LEVEL_RESET_RECOVERY,
161 	.hwini_ip_block_mask = AMDGPU_IP_BLK_MASK_ALL,
162 };
163 
164 /*
165  * Minimal blocks needed to be initialized before a XGMI hive can be reset. This
166  * is used for cases like reset on initialization where the entire hive needs to
167  * be reset before first use.
168  */
169 struct amdgpu_init_level amdgpu_init_minimal_xgmi = {
170 	.level = AMDGPU_INIT_LEVEL_MINIMAL_XGMI,
171 	.hwini_ip_block_mask =
172 		BIT(AMD_IP_BLOCK_TYPE_GMC) | BIT(AMD_IP_BLOCK_TYPE_SMC) |
173 		BIT(AMD_IP_BLOCK_TYPE_COMMON) | BIT(AMD_IP_BLOCK_TYPE_IH) |
174 		BIT(AMD_IP_BLOCK_TYPE_PSP)
175 };
176 
177 static inline bool amdgpu_ip_member_of_hwini(struct amdgpu_device *adev,
178 					     enum amd_ip_block_type block)
179 {
180 	return (adev->init_lvl->hwini_ip_block_mask & (1U << block)) != 0;
181 }
182 
183 void amdgpu_set_init_level(struct amdgpu_device *adev,
184 			   enum amdgpu_init_lvl_id lvl)
185 {
186 	switch (lvl) {
187 	case AMDGPU_INIT_LEVEL_MINIMAL_XGMI:
188 		adev->init_lvl = &amdgpu_init_minimal_xgmi;
189 		break;
190 	case AMDGPU_INIT_LEVEL_RESET_RECOVERY:
191 		adev->init_lvl = &amdgpu_init_recovery;
192 		break;
193 	case AMDGPU_INIT_LEVEL_DEFAULT:
194 		fallthrough;
195 	default:
196 		adev->init_lvl = &amdgpu_init_default;
197 		break;
198 	}
199 }
200 
201 static inline void amdgpu_device_stop_pending_resets(struct amdgpu_device *adev);
202 
203 /**
204  * DOC: pcie_replay_count
205  *
206  * The amdgpu driver provides a sysfs API for reporting the total number
207  * of PCIe replays (NAKs)
208  * The file pcie_replay_count is used for this and returns the total
209  * number of replays as a sum of the NAKs generated and NAKs received
210  */
211 
212 static ssize_t amdgpu_device_get_pcie_replay_count(struct device *dev,
213 		struct device_attribute *attr, char *buf)
214 {
215 	struct drm_device *ddev = dev_get_drvdata(dev);
216 	struct amdgpu_device *adev = drm_to_adev(ddev);
217 	uint64_t cnt = amdgpu_asic_get_pcie_replay_count(adev);
218 
219 	return sysfs_emit(buf, "%llu\n", cnt);
220 }
221 
222 static DEVICE_ATTR(pcie_replay_count, 0444,
223 		amdgpu_device_get_pcie_replay_count, NULL);
224 
225 static ssize_t amdgpu_sysfs_reg_state_get(struct file *f, struct kobject *kobj,
226 					  struct bin_attribute *attr, char *buf,
227 					  loff_t ppos, size_t count)
228 {
229 	struct device *dev = kobj_to_dev(kobj);
230 	struct drm_device *ddev = dev_get_drvdata(dev);
231 	struct amdgpu_device *adev = drm_to_adev(ddev);
232 	ssize_t bytes_read;
233 
234 	switch (ppos) {
235 	case AMDGPU_SYS_REG_STATE_XGMI:
236 		bytes_read = amdgpu_asic_get_reg_state(
237 			adev, AMDGPU_REG_STATE_TYPE_XGMI, buf, count);
238 		break;
239 	case AMDGPU_SYS_REG_STATE_WAFL:
240 		bytes_read = amdgpu_asic_get_reg_state(
241 			adev, AMDGPU_REG_STATE_TYPE_WAFL, buf, count);
242 		break;
243 	case AMDGPU_SYS_REG_STATE_PCIE:
244 		bytes_read = amdgpu_asic_get_reg_state(
245 			adev, AMDGPU_REG_STATE_TYPE_PCIE, buf, count);
246 		break;
247 	case AMDGPU_SYS_REG_STATE_USR:
248 		bytes_read = amdgpu_asic_get_reg_state(
249 			adev, AMDGPU_REG_STATE_TYPE_USR, buf, count);
250 		break;
251 	case AMDGPU_SYS_REG_STATE_USR_1:
252 		bytes_read = amdgpu_asic_get_reg_state(
253 			adev, AMDGPU_REG_STATE_TYPE_USR_1, buf, count);
254 		break;
255 	default:
256 		return -EINVAL;
257 	}
258 
259 	return bytes_read;
260 }
261 
262 BIN_ATTR(reg_state, 0444, amdgpu_sysfs_reg_state_get, NULL,
263 	 AMDGPU_SYS_REG_STATE_END);
264 
265 int amdgpu_reg_state_sysfs_init(struct amdgpu_device *adev)
266 {
267 	int ret;
268 
269 	if (!amdgpu_asic_get_reg_state_supported(adev))
270 		return 0;
271 
272 	ret = sysfs_create_bin_file(&adev->dev->kobj, &bin_attr_reg_state);
273 
274 	return ret;
275 }
276 
277 void amdgpu_reg_state_sysfs_fini(struct amdgpu_device *adev)
278 {
279 	if (!amdgpu_asic_get_reg_state_supported(adev))
280 		return;
281 	sysfs_remove_bin_file(&adev->dev->kobj, &bin_attr_reg_state);
282 }
283 
284 int amdgpu_ip_block_suspend(struct amdgpu_ip_block *ip_block)
285 {
286 	int r;
287 
288 	if (ip_block->version->funcs->suspend) {
289 		r = ip_block->version->funcs->suspend(ip_block);
290 		if (r) {
291 			dev_err(ip_block->adev->dev,
292 				"suspend of IP block <%s> failed %d\n",
293 				ip_block->version->funcs->name, r);
294 			return r;
295 		}
296 	}
297 
298 	ip_block->status.hw = false;
299 	return 0;
300 }
301 
302 int amdgpu_ip_block_resume(struct amdgpu_ip_block *ip_block)
303 {
304 	int r;
305 
306 	if (ip_block->version->funcs->resume) {
307 		r = ip_block->version->funcs->resume(ip_block);
308 		if (r) {
309 			dev_err(ip_block->adev->dev,
310 				"resume of IP block <%s> failed %d\n",
311 				ip_block->version->funcs->name, r);
312 			return r;
313 		}
314 	}
315 
316 	ip_block->status.hw = true;
317 	return 0;
318 }
319 
320 /**
321  * DOC: board_info
322  *
323  * The amdgpu driver provides a sysfs API for giving board related information.
324  * It provides the form factor information in the format
325  *
326  *   type : form factor
327  *
328  * Possible form factor values
329  *
330  * - "cem"		- PCIE CEM card
331  * - "oam"		- Open Compute Accelerator Module
332  * - "unknown"	- Not known
333  *
334  */
335 
336 static ssize_t amdgpu_device_get_board_info(struct device *dev,
337 					    struct device_attribute *attr,
338 					    char *buf)
339 {
340 	struct drm_device *ddev = dev_get_drvdata(dev);
341 	struct amdgpu_device *adev = drm_to_adev(ddev);
342 	enum amdgpu_pkg_type pkg_type = AMDGPU_PKG_TYPE_CEM;
343 	const char *pkg;
344 
345 	if (adev->smuio.funcs && adev->smuio.funcs->get_pkg_type)
346 		pkg_type = adev->smuio.funcs->get_pkg_type(adev);
347 
348 	switch (pkg_type) {
349 	case AMDGPU_PKG_TYPE_CEM:
350 		pkg = "cem";
351 		break;
352 	case AMDGPU_PKG_TYPE_OAM:
353 		pkg = "oam";
354 		break;
355 	default:
356 		pkg = "unknown";
357 		break;
358 	}
359 
360 	return sysfs_emit(buf, "%s : %s\n", "type", pkg);
361 }
362 
363 static DEVICE_ATTR(board_info, 0444, amdgpu_device_get_board_info, NULL);
364 
365 static struct attribute *amdgpu_board_attrs[] = {
366 	&dev_attr_board_info.attr,
367 	NULL,
368 };
369 
370 static umode_t amdgpu_board_attrs_is_visible(struct kobject *kobj,
371 					     struct attribute *attr, int n)
372 {
373 	struct device *dev = kobj_to_dev(kobj);
374 	struct drm_device *ddev = dev_get_drvdata(dev);
375 	struct amdgpu_device *adev = drm_to_adev(ddev);
376 
377 	if (adev->flags & AMD_IS_APU)
378 		return 0;
379 
380 	return attr->mode;
381 }
382 
383 static const struct attribute_group amdgpu_board_attrs_group = {
384 	.attrs = amdgpu_board_attrs,
385 	.is_visible = amdgpu_board_attrs_is_visible
386 };
387 
388 static void amdgpu_device_get_pcie_info(struct amdgpu_device *adev);
389 
390 
391 /**
392  * amdgpu_device_supports_px - Is the device a dGPU with ATPX power control
393  *
394  * @dev: drm_device pointer
395  *
396  * Returns true if the device is a dGPU with ATPX power control,
397  * otherwise return false.
398  */
399 bool amdgpu_device_supports_px(struct drm_device *dev)
400 {
401 	struct amdgpu_device *adev = drm_to_adev(dev);
402 
403 	if ((adev->flags & AMD_IS_PX) && !amdgpu_is_atpx_hybrid())
404 		return true;
405 	return false;
406 }
407 
408 /**
409  * amdgpu_device_supports_boco - Is the device a dGPU with ACPI power resources
410  *
411  * @dev: drm_device pointer
412  *
413  * Returns true if the device is a dGPU with ACPI power control,
414  * otherwise return false.
415  */
416 bool amdgpu_device_supports_boco(struct drm_device *dev)
417 {
418 	struct amdgpu_device *adev = drm_to_adev(dev);
419 
420 	if (adev->has_pr3 ||
421 	    ((adev->flags & AMD_IS_PX) && amdgpu_is_atpx_hybrid()))
422 		return true;
423 	return false;
424 }
425 
426 /**
427  * amdgpu_device_supports_baco - Does the device support BACO
428  *
429  * @dev: drm_device pointer
430  *
431  * Return:
432  * 1 if the device supporte BACO;
433  * 3 if the device support MACO (only works if BACO is supported)
434  * otherwise return 0.
435  */
436 int amdgpu_device_supports_baco(struct drm_device *dev)
437 {
438 	struct amdgpu_device *adev = drm_to_adev(dev);
439 
440 	return amdgpu_asic_supports_baco(adev);
441 }
442 
443 void amdgpu_device_detect_runtime_pm_mode(struct amdgpu_device *adev)
444 {
445 	struct drm_device *dev;
446 	int bamaco_support;
447 
448 	dev = adev_to_drm(adev);
449 
450 	adev->pm.rpm_mode = AMDGPU_RUNPM_NONE;
451 	bamaco_support = amdgpu_device_supports_baco(dev);
452 
453 	switch (amdgpu_runtime_pm) {
454 	case 2:
455 		if (bamaco_support & MACO_SUPPORT) {
456 			adev->pm.rpm_mode = AMDGPU_RUNPM_BAMACO;
457 			dev_info(adev->dev, "Forcing BAMACO for runtime pm\n");
458 		} else if (bamaco_support == BACO_SUPPORT) {
459 			adev->pm.rpm_mode = AMDGPU_RUNPM_BACO;
460 			dev_info(adev->dev, "Requested mode BAMACO not available,fallback to use BACO\n");
461 		}
462 		break;
463 	case 1:
464 		if (bamaco_support & BACO_SUPPORT) {
465 			adev->pm.rpm_mode = AMDGPU_RUNPM_BACO;
466 			dev_info(adev->dev, "Forcing BACO for runtime pm\n");
467 		}
468 		break;
469 	case -1:
470 	case -2:
471 		if (amdgpu_device_supports_px(dev)) { /* enable PX as runtime mode */
472 			adev->pm.rpm_mode = AMDGPU_RUNPM_PX;
473 			dev_info(adev->dev, "Using ATPX for runtime pm\n");
474 		} else if (amdgpu_device_supports_boco(dev)) { /* enable boco as runtime mode */
475 			adev->pm.rpm_mode = AMDGPU_RUNPM_BOCO;
476 			dev_info(adev->dev, "Using BOCO for runtime pm\n");
477 		} else {
478 			if (!bamaco_support)
479 				goto no_runtime_pm;
480 
481 			switch (adev->asic_type) {
482 			case CHIP_VEGA20:
483 			case CHIP_ARCTURUS:
484 				/* BACO are not supported on vega20 and arctrus */
485 				break;
486 			case CHIP_VEGA10:
487 				/* enable BACO as runpm mode if noretry=0 */
488 				if (!adev->gmc.noretry)
489 					adev->pm.rpm_mode = AMDGPU_RUNPM_BACO;
490 				break;
491 			default:
492 				/* enable BACO as runpm mode on CI+ */
493 				adev->pm.rpm_mode = AMDGPU_RUNPM_BACO;
494 				break;
495 			}
496 
497 			if (adev->pm.rpm_mode == AMDGPU_RUNPM_BACO) {
498 				if (bamaco_support & MACO_SUPPORT) {
499 					adev->pm.rpm_mode = AMDGPU_RUNPM_BAMACO;
500 					dev_info(adev->dev, "Using BAMACO for runtime pm\n");
501 				} else {
502 					dev_info(adev->dev, "Using BACO for runtime pm\n");
503 				}
504 			}
505 		}
506 		break;
507 	case 0:
508 		dev_info(adev->dev, "runtime pm is manually disabled\n");
509 		break;
510 	default:
511 		break;
512 	}
513 
514 no_runtime_pm:
515 	if (adev->pm.rpm_mode == AMDGPU_RUNPM_NONE)
516 		dev_info(adev->dev, "Runtime PM not available\n");
517 }
518 /**
519  * amdgpu_device_supports_smart_shift - Is the device dGPU with
520  * smart shift support
521  *
522  * @dev: drm_device pointer
523  *
524  * Returns true if the device is a dGPU with Smart Shift support,
525  * otherwise returns false.
526  */
527 bool amdgpu_device_supports_smart_shift(struct drm_device *dev)
528 {
529 	return (amdgpu_device_supports_boco(dev) &&
530 		amdgpu_acpi_is_power_shift_control_supported());
531 }
532 
533 /*
534  * VRAM access helper functions
535  */
536 
537 /**
538  * amdgpu_device_mm_access - access vram by MM_INDEX/MM_DATA
539  *
540  * @adev: amdgpu_device pointer
541  * @pos: offset of the buffer in vram
542  * @buf: virtual address of the buffer in system memory
543  * @size: read/write size, sizeof(@buf) must > @size
544  * @write: true - write to vram, otherwise - read from vram
545  */
546 void amdgpu_device_mm_access(struct amdgpu_device *adev, loff_t pos,
547 			     void *buf, size_t size, bool write)
548 {
549 	unsigned long flags;
550 	uint32_t hi = ~0, tmp = 0;
551 	uint32_t *data = buf;
552 	uint64_t last;
553 	int idx;
554 
555 	if (!drm_dev_enter(adev_to_drm(adev), &idx))
556 		return;
557 
558 	BUG_ON(!IS_ALIGNED(pos, 4) || !IS_ALIGNED(size, 4));
559 
560 	spin_lock_irqsave(&adev->mmio_idx_lock, flags);
561 	for (last = pos + size; pos < last; pos += 4) {
562 		tmp = pos >> 31;
563 
564 		WREG32_NO_KIQ(mmMM_INDEX, ((uint32_t)pos) | 0x80000000);
565 		if (tmp != hi) {
566 			WREG32_NO_KIQ(mmMM_INDEX_HI, tmp);
567 			hi = tmp;
568 		}
569 		if (write)
570 			WREG32_NO_KIQ(mmMM_DATA, *data++);
571 		else
572 			*data++ = RREG32_NO_KIQ(mmMM_DATA);
573 	}
574 
575 	spin_unlock_irqrestore(&adev->mmio_idx_lock, flags);
576 	drm_dev_exit(idx);
577 }
578 
579 /**
580  * amdgpu_device_aper_access - access vram by vram aperature
581  *
582  * @adev: amdgpu_device pointer
583  * @pos: offset of the buffer in vram
584  * @buf: virtual address of the buffer in system memory
585  * @size: read/write size, sizeof(@buf) must > @size
586  * @write: true - write to vram, otherwise - read from vram
587  *
588  * The return value means how many bytes have been transferred.
589  */
590 size_t amdgpu_device_aper_access(struct amdgpu_device *adev, loff_t pos,
591 				 void *buf, size_t size, bool write)
592 {
593 #ifdef CONFIG_64BIT
594 	void __iomem *addr;
595 	size_t count = 0;
596 	uint64_t last;
597 
598 	if (!adev->mman.aper_base_kaddr)
599 		return 0;
600 
601 	last = min(pos + size, adev->gmc.visible_vram_size);
602 	if (last > pos) {
603 		addr = adev->mman.aper_base_kaddr + pos;
604 		count = last - pos;
605 
606 		if (write) {
607 			memcpy_toio(addr, buf, count);
608 			/* Make sure HDP write cache flush happens without any reordering
609 			 * after the system memory contents are sent over PCIe device
610 			 */
611 			mb();
612 			amdgpu_device_flush_hdp(adev, NULL);
613 		} else {
614 			amdgpu_device_invalidate_hdp(adev, NULL);
615 			/* Make sure HDP read cache is invalidated before issuing a read
616 			 * to the PCIe device
617 			 */
618 			mb();
619 			memcpy_fromio(buf, addr, count);
620 		}
621 
622 	}
623 
624 	return count;
625 #else
626 	return 0;
627 #endif
628 }
629 
630 /**
631  * amdgpu_device_vram_access - read/write a buffer in vram
632  *
633  * @adev: amdgpu_device pointer
634  * @pos: offset of the buffer in vram
635  * @buf: virtual address of the buffer in system memory
636  * @size: read/write size, sizeof(@buf) must > @size
637  * @write: true - write to vram, otherwise - read from vram
638  */
639 void amdgpu_device_vram_access(struct amdgpu_device *adev, loff_t pos,
640 			       void *buf, size_t size, bool write)
641 {
642 	size_t count;
643 
644 	/* try to using vram apreature to access vram first */
645 	count = amdgpu_device_aper_access(adev, pos, buf, size, write);
646 	size -= count;
647 	if (size) {
648 		/* using MM to access rest vram */
649 		pos += count;
650 		buf += count;
651 		amdgpu_device_mm_access(adev, pos, buf, size, write);
652 	}
653 }
654 
655 /*
656  * register access helper functions.
657  */
658 
659 /* Check if hw access should be skipped because of hotplug or device error */
660 bool amdgpu_device_skip_hw_access(struct amdgpu_device *adev)
661 {
662 	if (adev->no_hw_access)
663 		return true;
664 
665 #ifdef CONFIG_LOCKDEP
666 	/*
667 	 * This is a bit complicated to understand, so worth a comment. What we assert
668 	 * here is that the GPU reset is not running on another thread in parallel.
669 	 *
670 	 * For this we trylock the read side of the reset semaphore, if that succeeds
671 	 * we know that the reset is not running in paralell.
672 	 *
673 	 * If the trylock fails we assert that we are either already holding the read
674 	 * side of the lock or are the reset thread itself and hold the write side of
675 	 * the lock.
676 	 */
677 	if (in_task()) {
678 		if (down_read_trylock(&adev->reset_domain->sem))
679 			up_read(&adev->reset_domain->sem);
680 		else
681 			lockdep_assert_held(&adev->reset_domain->sem);
682 	}
683 #endif
684 	return false;
685 }
686 
687 /**
688  * amdgpu_device_rreg - read a memory mapped IO or indirect register
689  *
690  * @adev: amdgpu_device pointer
691  * @reg: dword aligned register offset
692  * @acc_flags: access flags which require special behavior
693  *
694  * Returns the 32 bit value from the offset specified.
695  */
696 uint32_t amdgpu_device_rreg(struct amdgpu_device *adev,
697 			    uint32_t reg, uint32_t acc_flags)
698 {
699 	uint32_t ret;
700 
701 	if (amdgpu_device_skip_hw_access(adev))
702 		return 0;
703 
704 	if ((reg * 4) < adev->rmmio_size) {
705 		if (!(acc_flags & AMDGPU_REGS_NO_KIQ) &&
706 		    amdgpu_sriov_runtime(adev) &&
707 		    down_read_trylock(&adev->reset_domain->sem)) {
708 			ret = amdgpu_kiq_rreg(adev, reg, 0);
709 			up_read(&adev->reset_domain->sem);
710 		} else {
711 			ret = readl(((void __iomem *)adev->rmmio) + (reg * 4));
712 		}
713 	} else {
714 		ret = adev->pcie_rreg(adev, reg * 4);
715 	}
716 
717 	trace_amdgpu_device_rreg(adev->pdev->device, reg, ret);
718 
719 	return ret;
720 }
721 
722 /*
723  * MMIO register read with bytes helper functions
724  * @offset:bytes offset from MMIO start
725  */
726 
727 /**
728  * amdgpu_mm_rreg8 - read a memory mapped IO register
729  *
730  * @adev: amdgpu_device pointer
731  * @offset: byte aligned register offset
732  *
733  * Returns the 8 bit value from the offset specified.
734  */
735 uint8_t amdgpu_mm_rreg8(struct amdgpu_device *adev, uint32_t offset)
736 {
737 	if (amdgpu_device_skip_hw_access(adev))
738 		return 0;
739 
740 	if (offset < adev->rmmio_size)
741 		return (readb(adev->rmmio + offset));
742 	BUG();
743 }
744 
745 
746 /**
747  * amdgpu_device_xcc_rreg - read a memory mapped IO or indirect register with specific XCC
748  *
749  * @adev: amdgpu_device pointer
750  * @reg: dword aligned register offset
751  * @acc_flags: access flags which require special behavior
752  * @xcc_id: xcc accelerated compute core id
753  *
754  * Returns the 32 bit value from the offset specified.
755  */
756 uint32_t amdgpu_device_xcc_rreg(struct amdgpu_device *adev,
757 				uint32_t reg, uint32_t acc_flags,
758 				uint32_t xcc_id)
759 {
760 	uint32_t ret, rlcg_flag;
761 
762 	if (amdgpu_device_skip_hw_access(adev))
763 		return 0;
764 
765 	if ((reg * 4) < adev->rmmio_size) {
766 		if (amdgpu_sriov_vf(adev) &&
767 		    !amdgpu_sriov_runtime(adev) &&
768 		    adev->gfx.rlc.rlcg_reg_access_supported &&
769 		    amdgpu_virt_get_rlcg_reg_access_flag(adev, acc_flags,
770 							 GC_HWIP, false,
771 							 &rlcg_flag)) {
772 			ret = amdgpu_virt_rlcg_reg_rw(adev, reg, 0, rlcg_flag, GET_INST(GC, xcc_id));
773 		} else if (!(acc_flags & AMDGPU_REGS_NO_KIQ) &&
774 		    amdgpu_sriov_runtime(adev) &&
775 		    down_read_trylock(&adev->reset_domain->sem)) {
776 			ret = amdgpu_kiq_rreg(adev, reg, xcc_id);
777 			up_read(&adev->reset_domain->sem);
778 		} else {
779 			ret = readl(((void __iomem *)adev->rmmio) + (reg * 4));
780 		}
781 	} else {
782 		ret = adev->pcie_rreg(adev, reg * 4);
783 	}
784 
785 	return ret;
786 }
787 
788 /*
789  * MMIO register write with bytes helper functions
790  * @offset:bytes offset from MMIO start
791  * @value: the value want to be written to the register
792  */
793 
794 /**
795  * amdgpu_mm_wreg8 - read a memory mapped IO register
796  *
797  * @adev: amdgpu_device pointer
798  * @offset: byte aligned register offset
799  * @value: 8 bit value to write
800  *
801  * Writes the value specified to the offset specified.
802  */
803 void amdgpu_mm_wreg8(struct amdgpu_device *adev, uint32_t offset, uint8_t value)
804 {
805 	if (amdgpu_device_skip_hw_access(adev))
806 		return;
807 
808 	if (offset < adev->rmmio_size)
809 		writeb(value, adev->rmmio + offset);
810 	else
811 		BUG();
812 }
813 
814 /**
815  * amdgpu_device_wreg - write to a memory mapped IO or indirect register
816  *
817  * @adev: amdgpu_device pointer
818  * @reg: dword aligned register offset
819  * @v: 32 bit value to write to the register
820  * @acc_flags: access flags which require special behavior
821  *
822  * Writes the value specified to the offset specified.
823  */
824 void amdgpu_device_wreg(struct amdgpu_device *adev,
825 			uint32_t reg, uint32_t v,
826 			uint32_t acc_flags)
827 {
828 	if (amdgpu_device_skip_hw_access(adev))
829 		return;
830 
831 	if ((reg * 4) < adev->rmmio_size) {
832 		if (!(acc_flags & AMDGPU_REGS_NO_KIQ) &&
833 		    amdgpu_sriov_runtime(adev) &&
834 		    down_read_trylock(&adev->reset_domain->sem)) {
835 			amdgpu_kiq_wreg(adev, reg, v, 0);
836 			up_read(&adev->reset_domain->sem);
837 		} else {
838 			writel(v, ((void __iomem *)adev->rmmio) + (reg * 4));
839 		}
840 	} else {
841 		adev->pcie_wreg(adev, reg * 4, v);
842 	}
843 
844 	trace_amdgpu_device_wreg(adev->pdev->device, reg, v);
845 }
846 
847 /**
848  * amdgpu_mm_wreg_mmio_rlc -  write register either with direct/indirect mmio or with RLC path if in range
849  *
850  * @adev: amdgpu_device pointer
851  * @reg: mmio/rlc register
852  * @v: value to write
853  * @xcc_id: xcc accelerated compute core id
854  *
855  * this function is invoked only for the debugfs register access
856  */
857 void amdgpu_mm_wreg_mmio_rlc(struct amdgpu_device *adev,
858 			     uint32_t reg, uint32_t v,
859 			     uint32_t xcc_id)
860 {
861 	if (amdgpu_device_skip_hw_access(adev))
862 		return;
863 
864 	if (amdgpu_sriov_fullaccess(adev) &&
865 	    adev->gfx.rlc.funcs &&
866 	    adev->gfx.rlc.funcs->is_rlcg_access_range) {
867 		if (adev->gfx.rlc.funcs->is_rlcg_access_range(adev, reg))
868 			return amdgpu_sriov_wreg(adev, reg, v, 0, 0, xcc_id);
869 	} else if ((reg * 4) >= adev->rmmio_size) {
870 		adev->pcie_wreg(adev, reg * 4, v);
871 	} else {
872 		writel(v, ((void __iomem *)adev->rmmio) + (reg * 4));
873 	}
874 }
875 
876 /**
877  * amdgpu_device_xcc_wreg - write to a memory mapped IO or indirect register with specific XCC
878  *
879  * @adev: amdgpu_device pointer
880  * @reg: dword aligned register offset
881  * @v: 32 bit value to write to the register
882  * @acc_flags: access flags which require special behavior
883  * @xcc_id: xcc accelerated compute core id
884  *
885  * Writes the value specified to the offset specified.
886  */
887 void amdgpu_device_xcc_wreg(struct amdgpu_device *adev,
888 			uint32_t reg, uint32_t v,
889 			uint32_t acc_flags, uint32_t xcc_id)
890 {
891 	uint32_t rlcg_flag;
892 
893 	if (amdgpu_device_skip_hw_access(adev))
894 		return;
895 
896 	if ((reg * 4) < adev->rmmio_size) {
897 		if (amdgpu_sriov_vf(adev) &&
898 		    !amdgpu_sriov_runtime(adev) &&
899 		    adev->gfx.rlc.rlcg_reg_access_supported &&
900 		    amdgpu_virt_get_rlcg_reg_access_flag(adev, acc_flags,
901 							 GC_HWIP, true,
902 							 &rlcg_flag)) {
903 			amdgpu_virt_rlcg_reg_rw(adev, reg, v, rlcg_flag, GET_INST(GC, xcc_id));
904 		} else if (!(acc_flags & AMDGPU_REGS_NO_KIQ) &&
905 		    amdgpu_sriov_runtime(adev) &&
906 		    down_read_trylock(&adev->reset_domain->sem)) {
907 			amdgpu_kiq_wreg(adev, reg, v, xcc_id);
908 			up_read(&adev->reset_domain->sem);
909 		} else {
910 			writel(v, ((void __iomem *)adev->rmmio) + (reg * 4));
911 		}
912 	} else {
913 		adev->pcie_wreg(adev, reg * 4, v);
914 	}
915 }
916 
917 /**
918  * amdgpu_device_indirect_rreg - read an indirect register
919  *
920  * @adev: amdgpu_device pointer
921  * @reg_addr: indirect register address to read from
922  *
923  * Returns the value of indirect register @reg_addr
924  */
925 u32 amdgpu_device_indirect_rreg(struct amdgpu_device *adev,
926 				u32 reg_addr)
927 {
928 	unsigned long flags, pcie_index, pcie_data;
929 	void __iomem *pcie_index_offset;
930 	void __iomem *pcie_data_offset;
931 	u32 r;
932 
933 	pcie_index = adev->nbio.funcs->get_pcie_index_offset(adev);
934 	pcie_data = adev->nbio.funcs->get_pcie_data_offset(adev);
935 
936 	spin_lock_irqsave(&adev->pcie_idx_lock, flags);
937 	pcie_index_offset = (void __iomem *)adev->rmmio + pcie_index * 4;
938 	pcie_data_offset = (void __iomem *)adev->rmmio + pcie_data * 4;
939 
940 	writel(reg_addr, pcie_index_offset);
941 	readl(pcie_index_offset);
942 	r = readl(pcie_data_offset);
943 	spin_unlock_irqrestore(&adev->pcie_idx_lock, flags);
944 
945 	return r;
946 }
947 
948 u32 amdgpu_device_indirect_rreg_ext(struct amdgpu_device *adev,
949 				    u64 reg_addr)
950 {
951 	unsigned long flags, pcie_index, pcie_index_hi, pcie_data;
952 	u32 r;
953 	void __iomem *pcie_index_offset;
954 	void __iomem *pcie_index_hi_offset;
955 	void __iomem *pcie_data_offset;
956 
957 	if (unlikely(!adev->nbio.funcs)) {
958 		pcie_index = AMDGPU_PCIE_INDEX_FALLBACK;
959 		pcie_data = AMDGPU_PCIE_DATA_FALLBACK;
960 	} else {
961 		pcie_index = adev->nbio.funcs->get_pcie_index_offset(adev);
962 		pcie_data = adev->nbio.funcs->get_pcie_data_offset(adev);
963 	}
964 
965 	if (reg_addr >> 32) {
966 		if (unlikely(!adev->nbio.funcs))
967 			pcie_index_hi = AMDGPU_PCIE_INDEX_HI_FALLBACK;
968 		else
969 			pcie_index_hi = adev->nbio.funcs->get_pcie_index_hi_offset(adev);
970 	} else {
971 		pcie_index_hi = 0;
972 	}
973 
974 	spin_lock_irqsave(&adev->pcie_idx_lock, flags);
975 	pcie_index_offset = (void __iomem *)adev->rmmio + pcie_index * 4;
976 	pcie_data_offset = (void __iomem *)adev->rmmio + pcie_data * 4;
977 	if (pcie_index_hi != 0)
978 		pcie_index_hi_offset = (void __iomem *)adev->rmmio +
979 				pcie_index_hi * 4;
980 
981 	writel(reg_addr, pcie_index_offset);
982 	readl(pcie_index_offset);
983 	if (pcie_index_hi != 0) {
984 		writel((reg_addr >> 32) & 0xff, pcie_index_hi_offset);
985 		readl(pcie_index_hi_offset);
986 	}
987 	r = readl(pcie_data_offset);
988 
989 	/* clear the high bits */
990 	if (pcie_index_hi != 0) {
991 		writel(0, pcie_index_hi_offset);
992 		readl(pcie_index_hi_offset);
993 	}
994 
995 	spin_unlock_irqrestore(&adev->pcie_idx_lock, flags);
996 
997 	return r;
998 }
999 
1000 /**
1001  * amdgpu_device_indirect_rreg64 - read a 64bits indirect register
1002  *
1003  * @adev: amdgpu_device pointer
1004  * @reg_addr: indirect register address to read from
1005  *
1006  * Returns the value of indirect register @reg_addr
1007  */
1008 u64 amdgpu_device_indirect_rreg64(struct amdgpu_device *adev,
1009 				  u32 reg_addr)
1010 {
1011 	unsigned long flags, pcie_index, pcie_data;
1012 	void __iomem *pcie_index_offset;
1013 	void __iomem *pcie_data_offset;
1014 	u64 r;
1015 
1016 	pcie_index = adev->nbio.funcs->get_pcie_index_offset(adev);
1017 	pcie_data = adev->nbio.funcs->get_pcie_data_offset(adev);
1018 
1019 	spin_lock_irqsave(&adev->pcie_idx_lock, flags);
1020 	pcie_index_offset = (void __iomem *)adev->rmmio + pcie_index * 4;
1021 	pcie_data_offset = (void __iomem *)adev->rmmio + pcie_data * 4;
1022 
1023 	/* read low 32 bits */
1024 	writel(reg_addr, pcie_index_offset);
1025 	readl(pcie_index_offset);
1026 	r = readl(pcie_data_offset);
1027 	/* read high 32 bits */
1028 	writel(reg_addr + 4, pcie_index_offset);
1029 	readl(pcie_index_offset);
1030 	r |= ((u64)readl(pcie_data_offset) << 32);
1031 	spin_unlock_irqrestore(&adev->pcie_idx_lock, flags);
1032 
1033 	return r;
1034 }
1035 
1036 u64 amdgpu_device_indirect_rreg64_ext(struct amdgpu_device *adev,
1037 				  u64 reg_addr)
1038 {
1039 	unsigned long flags, pcie_index, pcie_data;
1040 	unsigned long pcie_index_hi = 0;
1041 	void __iomem *pcie_index_offset;
1042 	void __iomem *pcie_index_hi_offset;
1043 	void __iomem *pcie_data_offset;
1044 	u64 r;
1045 
1046 	pcie_index = adev->nbio.funcs->get_pcie_index_offset(adev);
1047 	pcie_data = adev->nbio.funcs->get_pcie_data_offset(adev);
1048 	if ((reg_addr >> 32) && (adev->nbio.funcs->get_pcie_index_hi_offset))
1049 		pcie_index_hi = adev->nbio.funcs->get_pcie_index_hi_offset(adev);
1050 
1051 	spin_lock_irqsave(&adev->pcie_idx_lock, flags);
1052 	pcie_index_offset = (void __iomem *)adev->rmmio + pcie_index * 4;
1053 	pcie_data_offset = (void __iomem *)adev->rmmio + pcie_data * 4;
1054 	if (pcie_index_hi != 0)
1055 		pcie_index_hi_offset = (void __iomem *)adev->rmmio +
1056 			pcie_index_hi * 4;
1057 
1058 	/* read low 32 bits */
1059 	writel(reg_addr, pcie_index_offset);
1060 	readl(pcie_index_offset);
1061 	if (pcie_index_hi != 0) {
1062 		writel((reg_addr >> 32) & 0xff, pcie_index_hi_offset);
1063 		readl(pcie_index_hi_offset);
1064 	}
1065 	r = readl(pcie_data_offset);
1066 	/* read high 32 bits */
1067 	writel(reg_addr + 4, pcie_index_offset);
1068 	readl(pcie_index_offset);
1069 	if (pcie_index_hi != 0) {
1070 		writel((reg_addr >> 32) & 0xff, pcie_index_hi_offset);
1071 		readl(pcie_index_hi_offset);
1072 	}
1073 	r |= ((u64)readl(pcie_data_offset) << 32);
1074 
1075 	/* clear the high bits */
1076 	if (pcie_index_hi != 0) {
1077 		writel(0, pcie_index_hi_offset);
1078 		readl(pcie_index_hi_offset);
1079 	}
1080 
1081 	spin_unlock_irqrestore(&adev->pcie_idx_lock, flags);
1082 
1083 	return r;
1084 }
1085 
1086 /**
1087  * amdgpu_device_indirect_wreg - write an indirect register address
1088  *
1089  * @adev: amdgpu_device pointer
1090  * @reg_addr: indirect register offset
1091  * @reg_data: indirect register data
1092  *
1093  */
1094 void amdgpu_device_indirect_wreg(struct amdgpu_device *adev,
1095 				 u32 reg_addr, u32 reg_data)
1096 {
1097 	unsigned long flags, pcie_index, pcie_data;
1098 	void __iomem *pcie_index_offset;
1099 	void __iomem *pcie_data_offset;
1100 
1101 	pcie_index = adev->nbio.funcs->get_pcie_index_offset(adev);
1102 	pcie_data = adev->nbio.funcs->get_pcie_data_offset(adev);
1103 
1104 	spin_lock_irqsave(&adev->pcie_idx_lock, flags);
1105 	pcie_index_offset = (void __iomem *)adev->rmmio + pcie_index * 4;
1106 	pcie_data_offset = (void __iomem *)adev->rmmio + pcie_data * 4;
1107 
1108 	writel(reg_addr, pcie_index_offset);
1109 	readl(pcie_index_offset);
1110 	writel(reg_data, pcie_data_offset);
1111 	readl(pcie_data_offset);
1112 	spin_unlock_irqrestore(&adev->pcie_idx_lock, flags);
1113 }
1114 
1115 void amdgpu_device_indirect_wreg_ext(struct amdgpu_device *adev,
1116 				     u64 reg_addr, u32 reg_data)
1117 {
1118 	unsigned long flags, pcie_index, pcie_index_hi, pcie_data;
1119 	void __iomem *pcie_index_offset;
1120 	void __iomem *pcie_index_hi_offset;
1121 	void __iomem *pcie_data_offset;
1122 
1123 	pcie_index = adev->nbio.funcs->get_pcie_index_offset(adev);
1124 	pcie_data = adev->nbio.funcs->get_pcie_data_offset(adev);
1125 	if ((reg_addr >> 32) && (adev->nbio.funcs->get_pcie_index_hi_offset))
1126 		pcie_index_hi = adev->nbio.funcs->get_pcie_index_hi_offset(adev);
1127 	else
1128 		pcie_index_hi = 0;
1129 
1130 	spin_lock_irqsave(&adev->pcie_idx_lock, flags);
1131 	pcie_index_offset = (void __iomem *)adev->rmmio + pcie_index * 4;
1132 	pcie_data_offset = (void __iomem *)adev->rmmio + pcie_data * 4;
1133 	if (pcie_index_hi != 0)
1134 		pcie_index_hi_offset = (void __iomem *)adev->rmmio +
1135 				pcie_index_hi * 4;
1136 
1137 	writel(reg_addr, pcie_index_offset);
1138 	readl(pcie_index_offset);
1139 	if (pcie_index_hi != 0) {
1140 		writel((reg_addr >> 32) & 0xff, pcie_index_hi_offset);
1141 		readl(pcie_index_hi_offset);
1142 	}
1143 	writel(reg_data, pcie_data_offset);
1144 	readl(pcie_data_offset);
1145 
1146 	/* clear the high bits */
1147 	if (pcie_index_hi != 0) {
1148 		writel(0, pcie_index_hi_offset);
1149 		readl(pcie_index_hi_offset);
1150 	}
1151 
1152 	spin_unlock_irqrestore(&adev->pcie_idx_lock, flags);
1153 }
1154 
1155 /**
1156  * amdgpu_device_indirect_wreg64 - write a 64bits indirect register address
1157  *
1158  * @adev: amdgpu_device pointer
1159  * @reg_addr: indirect register offset
1160  * @reg_data: indirect register data
1161  *
1162  */
1163 void amdgpu_device_indirect_wreg64(struct amdgpu_device *adev,
1164 				   u32 reg_addr, u64 reg_data)
1165 {
1166 	unsigned long flags, pcie_index, pcie_data;
1167 	void __iomem *pcie_index_offset;
1168 	void __iomem *pcie_data_offset;
1169 
1170 	pcie_index = adev->nbio.funcs->get_pcie_index_offset(adev);
1171 	pcie_data = adev->nbio.funcs->get_pcie_data_offset(adev);
1172 
1173 	spin_lock_irqsave(&adev->pcie_idx_lock, flags);
1174 	pcie_index_offset = (void __iomem *)adev->rmmio + pcie_index * 4;
1175 	pcie_data_offset = (void __iomem *)adev->rmmio + pcie_data * 4;
1176 
1177 	/* write low 32 bits */
1178 	writel(reg_addr, pcie_index_offset);
1179 	readl(pcie_index_offset);
1180 	writel((u32)(reg_data & 0xffffffffULL), pcie_data_offset);
1181 	readl(pcie_data_offset);
1182 	/* write high 32 bits */
1183 	writel(reg_addr + 4, pcie_index_offset);
1184 	readl(pcie_index_offset);
1185 	writel((u32)(reg_data >> 32), pcie_data_offset);
1186 	readl(pcie_data_offset);
1187 	spin_unlock_irqrestore(&adev->pcie_idx_lock, flags);
1188 }
1189 
1190 void amdgpu_device_indirect_wreg64_ext(struct amdgpu_device *adev,
1191 				   u64 reg_addr, u64 reg_data)
1192 {
1193 	unsigned long flags, pcie_index, pcie_data;
1194 	unsigned long pcie_index_hi = 0;
1195 	void __iomem *pcie_index_offset;
1196 	void __iomem *pcie_index_hi_offset;
1197 	void __iomem *pcie_data_offset;
1198 
1199 	pcie_index = adev->nbio.funcs->get_pcie_index_offset(adev);
1200 	pcie_data = adev->nbio.funcs->get_pcie_data_offset(adev);
1201 	if ((reg_addr >> 32) && (adev->nbio.funcs->get_pcie_index_hi_offset))
1202 		pcie_index_hi = adev->nbio.funcs->get_pcie_index_hi_offset(adev);
1203 
1204 	spin_lock_irqsave(&adev->pcie_idx_lock, flags);
1205 	pcie_index_offset = (void __iomem *)adev->rmmio + pcie_index * 4;
1206 	pcie_data_offset = (void __iomem *)adev->rmmio + pcie_data * 4;
1207 	if (pcie_index_hi != 0)
1208 		pcie_index_hi_offset = (void __iomem *)adev->rmmio +
1209 				pcie_index_hi * 4;
1210 
1211 	/* write low 32 bits */
1212 	writel(reg_addr, pcie_index_offset);
1213 	readl(pcie_index_offset);
1214 	if (pcie_index_hi != 0) {
1215 		writel((reg_addr >> 32) & 0xff, pcie_index_hi_offset);
1216 		readl(pcie_index_hi_offset);
1217 	}
1218 	writel((u32)(reg_data & 0xffffffffULL), pcie_data_offset);
1219 	readl(pcie_data_offset);
1220 	/* write high 32 bits */
1221 	writel(reg_addr + 4, pcie_index_offset);
1222 	readl(pcie_index_offset);
1223 	if (pcie_index_hi != 0) {
1224 		writel((reg_addr >> 32) & 0xff, pcie_index_hi_offset);
1225 		readl(pcie_index_hi_offset);
1226 	}
1227 	writel((u32)(reg_data >> 32), pcie_data_offset);
1228 	readl(pcie_data_offset);
1229 
1230 	/* clear the high bits */
1231 	if (pcie_index_hi != 0) {
1232 		writel(0, pcie_index_hi_offset);
1233 		readl(pcie_index_hi_offset);
1234 	}
1235 
1236 	spin_unlock_irqrestore(&adev->pcie_idx_lock, flags);
1237 }
1238 
1239 /**
1240  * amdgpu_device_get_rev_id - query device rev_id
1241  *
1242  * @adev: amdgpu_device pointer
1243  *
1244  * Return device rev_id
1245  */
1246 u32 amdgpu_device_get_rev_id(struct amdgpu_device *adev)
1247 {
1248 	return adev->nbio.funcs->get_rev_id(adev);
1249 }
1250 
1251 /**
1252  * amdgpu_invalid_rreg - dummy reg read function
1253  *
1254  * @adev: amdgpu_device pointer
1255  * @reg: offset of register
1256  *
1257  * Dummy register read function.  Used for register blocks
1258  * that certain asics don't have (all asics).
1259  * Returns the value in the register.
1260  */
1261 static uint32_t amdgpu_invalid_rreg(struct amdgpu_device *adev, uint32_t reg)
1262 {
1263 	DRM_ERROR("Invalid callback to read register 0x%04X\n", reg);
1264 	BUG();
1265 	return 0;
1266 }
1267 
1268 static uint32_t amdgpu_invalid_rreg_ext(struct amdgpu_device *adev, uint64_t reg)
1269 {
1270 	DRM_ERROR("Invalid callback to read register 0x%llX\n", reg);
1271 	BUG();
1272 	return 0;
1273 }
1274 
1275 /**
1276  * amdgpu_invalid_wreg - dummy reg write function
1277  *
1278  * @adev: amdgpu_device pointer
1279  * @reg: offset of register
1280  * @v: value to write to the register
1281  *
1282  * Dummy register read function.  Used for register blocks
1283  * that certain asics don't have (all asics).
1284  */
1285 static void amdgpu_invalid_wreg(struct amdgpu_device *adev, uint32_t reg, uint32_t v)
1286 {
1287 	DRM_ERROR("Invalid callback to write register 0x%04X with 0x%08X\n",
1288 		  reg, v);
1289 	BUG();
1290 }
1291 
1292 static void amdgpu_invalid_wreg_ext(struct amdgpu_device *adev, uint64_t reg, uint32_t v)
1293 {
1294 	DRM_ERROR("Invalid callback to write register 0x%llX with 0x%08X\n",
1295 		  reg, v);
1296 	BUG();
1297 }
1298 
1299 /**
1300  * amdgpu_invalid_rreg64 - dummy 64 bit reg read function
1301  *
1302  * @adev: amdgpu_device pointer
1303  * @reg: offset of register
1304  *
1305  * Dummy register read function.  Used for register blocks
1306  * that certain asics don't have (all asics).
1307  * Returns the value in the register.
1308  */
1309 static uint64_t amdgpu_invalid_rreg64(struct amdgpu_device *adev, uint32_t reg)
1310 {
1311 	DRM_ERROR("Invalid callback to read 64 bit register 0x%04X\n", reg);
1312 	BUG();
1313 	return 0;
1314 }
1315 
1316 static uint64_t amdgpu_invalid_rreg64_ext(struct amdgpu_device *adev, uint64_t reg)
1317 {
1318 	DRM_ERROR("Invalid callback to read register 0x%llX\n", reg);
1319 	BUG();
1320 	return 0;
1321 }
1322 
1323 /**
1324  * amdgpu_invalid_wreg64 - dummy reg write function
1325  *
1326  * @adev: amdgpu_device pointer
1327  * @reg: offset of register
1328  * @v: value to write to the register
1329  *
1330  * Dummy register read function.  Used for register blocks
1331  * that certain asics don't have (all asics).
1332  */
1333 static void amdgpu_invalid_wreg64(struct amdgpu_device *adev, uint32_t reg, uint64_t v)
1334 {
1335 	DRM_ERROR("Invalid callback to write 64 bit register 0x%04X with 0x%08llX\n",
1336 		  reg, v);
1337 	BUG();
1338 }
1339 
1340 static void amdgpu_invalid_wreg64_ext(struct amdgpu_device *adev, uint64_t reg, uint64_t v)
1341 {
1342 	DRM_ERROR("Invalid callback to write 64 bit register 0x%llX with 0x%08llX\n",
1343 		  reg, v);
1344 	BUG();
1345 }
1346 
1347 /**
1348  * amdgpu_block_invalid_rreg - dummy reg read function
1349  *
1350  * @adev: amdgpu_device pointer
1351  * @block: offset of instance
1352  * @reg: offset of register
1353  *
1354  * Dummy register read function.  Used for register blocks
1355  * that certain asics don't have (all asics).
1356  * Returns the value in the register.
1357  */
1358 static uint32_t amdgpu_block_invalid_rreg(struct amdgpu_device *adev,
1359 					  uint32_t block, uint32_t reg)
1360 {
1361 	DRM_ERROR("Invalid callback to read register 0x%04X in block 0x%04X\n",
1362 		  reg, block);
1363 	BUG();
1364 	return 0;
1365 }
1366 
1367 /**
1368  * amdgpu_block_invalid_wreg - dummy reg write function
1369  *
1370  * @adev: amdgpu_device pointer
1371  * @block: offset of instance
1372  * @reg: offset of register
1373  * @v: value to write to the register
1374  *
1375  * Dummy register read function.  Used for register blocks
1376  * that certain asics don't have (all asics).
1377  */
1378 static void amdgpu_block_invalid_wreg(struct amdgpu_device *adev,
1379 				      uint32_t block,
1380 				      uint32_t reg, uint32_t v)
1381 {
1382 	DRM_ERROR("Invalid block callback to write register 0x%04X in block 0x%04X with 0x%08X\n",
1383 		  reg, block, v);
1384 	BUG();
1385 }
1386 
1387 /**
1388  * amdgpu_device_asic_init - Wrapper for atom asic_init
1389  *
1390  * @adev: amdgpu_device pointer
1391  *
1392  * Does any asic specific work and then calls atom asic init.
1393  */
1394 static int amdgpu_device_asic_init(struct amdgpu_device *adev)
1395 {
1396 	int ret;
1397 
1398 	amdgpu_asic_pre_asic_init(adev);
1399 
1400 	if (amdgpu_ip_version(adev, GC_HWIP, 0) == IP_VERSION(9, 4, 3) ||
1401 	    amdgpu_ip_version(adev, GC_HWIP, 0) == IP_VERSION(9, 4, 4) ||
1402 	    amdgpu_ip_version(adev, GC_HWIP, 0) >= IP_VERSION(11, 0, 0)) {
1403 		amdgpu_psp_wait_for_bootloader(adev);
1404 		ret = amdgpu_atomfirmware_asic_init(adev, true);
1405 		return ret;
1406 	} else {
1407 		return amdgpu_atom_asic_init(adev->mode_info.atom_context);
1408 	}
1409 
1410 	return 0;
1411 }
1412 
1413 /**
1414  * amdgpu_device_mem_scratch_init - allocate the VRAM scratch page
1415  *
1416  * @adev: amdgpu_device pointer
1417  *
1418  * Allocates a scratch page of VRAM for use by various things in the
1419  * driver.
1420  */
1421 static int amdgpu_device_mem_scratch_init(struct amdgpu_device *adev)
1422 {
1423 	return amdgpu_bo_create_kernel(adev, AMDGPU_GPU_PAGE_SIZE, PAGE_SIZE,
1424 				       AMDGPU_GEM_DOMAIN_VRAM |
1425 				       AMDGPU_GEM_DOMAIN_GTT,
1426 				       &adev->mem_scratch.robj,
1427 				       &adev->mem_scratch.gpu_addr,
1428 				       (void **)&adev->mem_scratch.ptr);
1429 }
1430 
1431 /**
1432  * amdgpu_device_mem_scratch_fini - Free the VRAM scratch page
1433  *
1434  * @adev: amdgpu_device pointer
1435  *
1436  * Frees the VRAM scratch page.
1437  */
1438 static void amdgpu_device_mem_scratch_fini(struct amdgpu_device *adev)
1439 {
1440 	amdgpu_bo_free_kernel(&adev->mem_scratch.robj, NULL, NULL);
1441 }
1442 
1443 /**
1444  * amdgpu_device_program_register_sequence - program an array of registers.
1445  *
1446  * @adev: amdgpu_device pointer
1447  * @registers: pointer to the register array
1448  * @array_size: size of the register array
1449  *
1450  * Programs an array or registers with and or masks.
1451  * This is a helper for setting golden registers.
1452  */
1453 void amdgpu_device_program_register_sequence(struct amdgpu_device *adev,
1454 					     const u32 *registers,
1455 					     const u32 array_size)
1456 {
1457 	u32 tmp, reg, and_mask, or_mask;
1458 	int i;
1459 
1460 	if (array_size % 3)
1461 		return;
1462 
1463 	for (i = 0; i < array_size; i += 3) {
1464 		reg = registers[i + 0];
1465 		and_mask = registers[i + 1];
1466 		or_mask = registers[i + 2];
1467 
1468 		if (and_mask == 0xffffffff) {
1469 			tmp = or_mask;
1470 		} else {
1471 			tmp = RREG32(reg);
1472 			tmp &= ~and_mask;
1473 			if (adev->family >= AMDGPU_FAMILY_AI)
1474 				tmp |= (or_mask & and_mask);
1475 			else
1476 				tmp |= or_mask;
1477 		}
1478 		WREG32(reg, tmp);
1479 	}
1480 }
1481 
1482 /**
1483  * amdgpu_device_pci_config_reset - reset the GPU
1484  *
1485  * @adev: amdgpu_device pointer
1486  *
1487  * Resets the GPU using the pci config reset sequence.
1488  * Only applicable to asics prior to vega10.
1489  */
1490 void amdgpu_device_pci_config_reset(struct amdgpu_device *adev)
1491 {
1492 	pci_write_config_dword(adev->pdev, 0x7c, AMDGPU_ASIC_RESET_DATA);
1493 }
1494 
1495 /**
1496  * amdgpu_device_pci_reset - reset the GPU using generic PCI means
1497  *
1498  * @adev: amdgpu_device pointer
1499  *
1500  * Resets the GPU using generic pci reset interfaces (FLR, SBR, etc.).
1501  */
1502 int amdgpu_device_pci_reset(struct amdgpu_device *adev)
1503 {
1504 	return pci_reset_function(adev->pdev);
1505 }
1506 
1507 /*
1508  * amdgpu_device_wb_*()
1509  * Writeback is the method by which the GPU updates special pages in memory
1510  * with the status of certain GPU events (fences, ring pointers,etc.).
1511  */
1512 
1513 /**
1514  * amdgpu_device_wb_fini - Disable Writeback and free memory
1515  *
1516  * @adev: amdgpu_device pointer
1517  *
1518  * Disables Writeback and frees the Writeback memory (all asics).
1519  * Used at driver shutdown.
1520  */
1521 static void amdgpu_device_wb_fini(struct amdgpu_device *adev)
1522 {
1523 	if (adev->wb.wb_obj) {
1524 		amdgpu_bo_free_kernel(&adev->wb.wb_obj,
1525 				      &adev->wb.gpu_addr,
1526 				      (void **)&adev->wb.wb);
1527 		adev->wb.wb_obj = NULL;
1528 	}
1529 }
1530 
1531 /**
1532  * amdgpu_device_wb_init - Init Writeback driver info and allocate memory
1533  *
1534  * @adev: amdgpu_device pointer
1535  *
1536  * Initializes writeback and allocates writeback memory (all asics).
1537  * Used at driver startup.
1538  * Returns 0 on success or an -error on failure.
1539  */
1540 static int amdgpu_device_wb_init(struct amdgpu_device *adev)
1541 {
1542 	int r;
1543 
1544 	if (adev->wb.wb_obj == NULL) {
1545 		/* AMDGPU_MAX_WB * sizeof(uint32_t) * 8 = AMDGPU_MAX_WB 256bit slots */
1546 		r = amdgpu_bo_create_kernel(adev, AMDGPU_MAX_WB * sizeof(uint32_t) * 8,
1547 					    PAGE_SIZE, AMDGPU_GEM_DOMAIN_GTT,
1548 					    &adev->wb.wb_obj, &adev->wb.gpu_addr,
1549 					    (void **)&adev->wb.wb);
1550 		if (r) {
1551 			dev_warn(adev->dev, "(%d) create WB bo failed\n", r);
1552 			return r;
1553 		}
1554 
1555 		adev->wb.num_wb = AMDGPU_MAX_WB;
1556 		memset(&adev->wb.used, 0, sizeof(adev->wb.used));
1557 
1558 		/* clear wb memory */
1559 		memset((char *)adev->wb.wb, 0, AMDGPU_MAX_WB * sizeof(uint32_t) * 8);
1560 	}
1561 
1562 	return 0;
1563 }
1564 
1565 /**
1566  * amdgpu_device_wb_get - Allocate a wb entry
1567  *
1568  * @adev: amdgpu_device pointer
1569  * @wb: wb index
1570  *
1571  * Allocate a wb slot for use by the driver (all asics).
1572  * Returns 0 on success or -EINVAL on failure.
1573  */
1574 int amdgpu_device_wb_get(struct amdgpu_device *adev, u32 *wb)
1575 {
1576 	unsigned long flags, offset;
1577 
1578 	spin_lock_irqsave(&adev->wb.lock, flags);
1579 	offset = find_first_zero_bit(adev->wb.used, adev->wb.num_wb);
1580 	if (offset < adev->wb.num_wb) {
1581 		__set_bit(offset, adev->wb.used);
1582 		spin_unlock_irqrestore(&adev->wb.lock, flags);
1583 		*wb = offset << 3; /* convert to dw offset */
1584 		return 0;
1585 	} else {
1586 		spin_unlock_irqrestore(&adev->wb.lock, flags);
1587 		return -EINVAL;
1588 	}
1589 }
1590 
1591 /**
1592  * amdgpu_device_wb_free - Free a wb entry
1593  *
1594  * @adev: amdgpu_device pointer
1595  * @wb: wb index
1596  *
1597  * Free a wb slot allocated for use by the driver (all asics)
1598  */
1599 void amdgpu_device_wb_free(struct amdgpu_device *adev, u32 wb)
1600 {
1601 	unsigned long flags;
1602 
1603 	wb >>= 3;
1604 	spin_lock_irqsave(&adev->wb.lock, flags);
1605 	if (wb < adev->wb.num_wb)
1606 		__clear_bit(wb, adev->wb.used);
1607 	spin_unlock_irqrestore(&adev->wb.lock, flags);
1608 }
1609 
1610 /**
1611  * amdgpu_device_resize_fb_bar - try to resize FB BAR
1612  *
1613  * @adev: amdgpu_device pointer
1614  *
1615  * Try to resize FB BAR to make all VRAM CPU accessible. We try very hard not
1616  * to fail, but if any of the BARs is not accessible after the size we abort
1617  * driver loading by returning -ENODEV.
1618  */
1619 int amdgpu_device_resize_fb_bar(struct amdgpu_device *adev)
1620 {
1621 	int rbar_size = pci_rebar_bytes_to_size(adev->gmc.real_vram_size);
1622 	struct pci_bus *root;
1623 	struct resource *res;
1624 	unsigned int i;
1625 	u16 cmd;
1626 	int r;
1627 
1628 	if (!IS_ENABLED(CONFIG_PHYS_ADDR_T_64BIT))
1629 		return 0;
1630 
1631 	/* Bypass for VF */
1632 	if (amdgpu_sriov_vf(adev))
1633 		return 0;
1634 
1635 	/* PCI_EXT_CAP_ID_VNDR extended capability is located at 0x100 */
1636 	if (!pci_find_ext_capability(adev->pdev, PCI_EXT_CAP_ID_VNDR))
1637 		DRM_WARN("System can't access extended configuration space, please check!!\n");
1638 
1639 	/* skip if the bios has already enabled large BAR */
1640 	if (adev->gmc.real_vram_size &&
1641 	    (pci_resource_len(adev->pdev, 0) >= adev->gmc.real_vram_size))
1642 		return 0;
1643 
1644 	/* Check if the root BUS has 64bit memory resources */
1645 	root = adev->pdev->bus;
1646 	while (root->parent)
1647 		root = root->parent;
1648 
1649 	pci_bus_for_each_resource(root, res, i) {
1650 		if (res && res->flags & (IORESOURCE_MEM | IORESOURCE_MEM_64) &&
1651 		    res->start > 0x100000000ull)
1652 			break;
1653 	}
1654 
1655 	/* Trying to resize is pointless without a root hub window above 4GB */
1656 	if (!res)
1657 		return 0;
1658 
1659 	/* Limit the BAR size to what is available */
1660 	rbar_size = min(fls(pci_rebar_get_possible_sizes(adev->pdev, 0)) - 1,
1661 			rbar_size);
1662 
1663 	/* Disable memory decoding while we change the BAR addresses and size */
1664 	pci_read_config_word(adev->pdev, PCI_COMMAND, &cmd);
1665 	pci_write_config_word(adev->pdev, PCI_COMMAND,
1666 			      cmd & ~PCI_COMMAND_MEMORY);
1667 
1668 	/* Free the VRAM and doorbell BAR, we most likely need to move both. */
1669 	amdgpu_doorbell_fini(adev);
1670 	if (adev->asic_type >= CHIP_BONAIRE)
1671 		pci_release_resource(adev->pdev, 2);
1672 
1673 	pci_release_resource(adev->pdev, 0);
1674 
1675 	r = pci_resize_resource(adev->pdev, 0, rbar_size);
1676 	if (r == -ENOSPC)
1677 		DRM_INFO("Not enough PCI address space for a large BAR.");
1678 	else if (r && r != -ENOTSUPP)
1679 		DRM_ERROR("Problem resizing BAR0 (%d).", r);
1680 
1681 	pci_assign_unassigned_bus_resources(adev->pdev->bus);
1682 
1683 	/* When the doorbell or fb BAR isn't available we have no chance of
1684 	 * using the device.
1685 	 */
1686 	r = amdgpu_doorbell_init(adev);
1687 	if (r || (pci_resource_flags(adev->pdev, 0) & IORESOURCE_UNSET))
1688 		return -ENODEV;
1689 
1690 	pci_write_config_word(adev->pdev, PCI_COMMAND, cmd);
1691 
1692 	return 0;
1693 }
1694 
1695 static bool amdgpu_device_read_bios(struct amdgpu_device *adev)
1696 {
1697 	if (hweight32(adev->aid_mask) && (adev->flags & AMD_IS_APU))
1698 		return false;
1699 
1700 	return true;
1701 }
1702 
1703 /*
1704  * GPU helpers function.
1705  */
1706 /**
1707  * amdgpu_device_need_post - check if the hw need post or not
1708  *
1709  * @adev: amdgpu_device pointer
1710  *
1711  * Check if the asic has been initialized (all asics) at driver startup
1712  * or post is needed if  hw reset is performed.
1713  * Returns true if need or false if not.
1714  */
1715 bool amdgpu_device_need_post(struct amdgpu_device *adev)
1716 {
1717 	uint32_t reg;
1718 
1719 	if (amdgpu_sriov_vf(adev))
1720 		return false;
1721 
1722 	if (!amdgpu_device_read_bios(adev))
1723 		return false;
1724 
1725 	if (amdgpu_passthrough(adev)) {
1726 		/* for FIJI: In whole GPU pass-through virtualization case, after VM reboot
1727 		 * some old smc fw still need driver do vPost otherwise gpu hang, while
1728 		 * those smc fw version above 22.15 doesn't have this flaw, so we force
1729 		 * vpost executed for smc version below 22.15
1730 		 */
1731 		if (adev->asic_type == CHIP_FIJI) {
1732 			int err;
1733 			uint32_t fw_ver;
1734 
1735 			err = request_firmware(&adev->pm.fw, "amdgpu/fiji_smc.bin", adev->dev);
1736 			/* force vPost if error occured */
1737 			if (err)
1738 				return true;
1739 
1740 			fw_ver = *((uint32_t *)adev->pm.fw->data + 69);
1741 			release_firmware(adev->pm.fw);
1742 			if (fw_ver < 0x00160e00)
1743 				return true;
1744 		}
1745 	}
1746 
1747 	/* Don't post if we need to reset whole hive on init */
1748 	if (adev->init_lvl->level == AMDGPU_INIT_LEVEL_MINIMAL_XGMI)
1749 		return false;
1750 
1751 	if (adev->has_hw_reset) {
1752 		adev->has_hw_reset = false;
1753 		return true;
1754 	}
1755 
1756 	/* bios scratch used on CIK+ */
1757 	if (adev->asic_type >= CHIP_BONAIRE)
1758 		return amdgpu_atombios_scratch_need_asic_init(adev);
1759 
1760 	/* check MEM_SIZE for older asics */
1761 	reg = amdgpu_asic_get_config_memsize(adev);
1762 
1763 	if ((reg != 0) && (reg != 0xffffffff))
1764 		return false;
1765 
1766 	return true;
1767 }
1768 
1769 /*
1770  * Check whether seamless boot is supported.
1771  *
1772  * So far we only support seamless boot on DCE 3.0 or later.
1773  * If users report that it works on older ASICS as well, we may
1774  * loosen this.
1775  */
1776 bool amdgpu_device_seamless_boot_supported(struct amdgpu_device *adev)
1777 {
1778 	switch (amdgpu_seamless) {
1779 	case -1:
1780 		break;
1781 	case 1:
1782 		return true;
1783 	case 0:
1784 		return false;
1785 	default:
1786 		DRM_ERROR("Invalid value for amdgpu.seamless: %d\n",
1787 			  amdgpu_seamless);
1788 		return false;
1789 	}
1790 
1791 	if (!(adev->flags & AMD_IS_APU))
1792 		return false;
1793 
1794 	if (adev->mman.keep_stolen_vga_memory)
1795 		return false;
1796 
1797 	return amdgpu_ip_version(adev, DCE_HWIP, 0) >= IP_VERSION(3, 0, 0);
1798 }
1799 
1800 /*
1801  * Intel hosts such as Rocket Lake, Alder Lake, Raptor Lake and Sapphire Rapids
1802  * don't support dynamic speed switching. Until we have confirmation from Intel
1803  * that a specific host supports it, it's safer that we keep it disabled for all.
1804  *
1805  * https://edc.intel.com/content/www/us/en/design/products/platforms/details/raptor-lake-s/13th-generation-core-processors-datasheet-volume-1-of-2/005/pci-express-support/
1806  * https://gitlab.freedesktop.org/drm/amd/-/issues/2663
1807  */
1808 static bool amdgpu_device_pcie_dynamic_switching_supported(struct amdgpu_device *adev)
1809 {
1810 #if IS_ENABLED(CONFIG_X86)
1811 	struct cpuinfo_x86 *c = &cpu_data(0);
1812 
1813 	/* eGPU change speeds based on USB4 fabric conditions */
1814 	if (dev_is_removable(adev->dev))
1815 		return true;
1816 
1817 	if (c->x86_vendor == X86_VENDOR_INTEL)
1818 		return false;
1819 #endif
1820 	return true;
1821 }
1822 
1823 /**
1824  * amdgpu_device_should_use_aspm - check if the device should program ASPM
1825  *
1826  * @adev: amdgpu_device pointer
1827  *
1828  * Confirm whether the module parameter and pcie bridge agree that ASPM should
1829  * be set for this device.
1830  *
1831  * Returns true if it should be used or false if not.
1832  */
1833 bool amdgpu_device_should_use_aspm(struct amdgpu_device *adev)
1834 {
1835 	switch (amdgpu_aspm) {
1836 	case -1:
1837 		break;
1838 	case 0:
1839 		return false;
1840 	case 1:
1841 		return true;
1842 	default:
1843 		return false;
1844 	}
1845 	if (adev->flags & AMD_IS_APU)
1846 		return false;
1847 	if (!(adev->pm.pp_feature & PP_PCIE_DPM_MASK))
1848 		return false;
1849 	return pcie_aspm_enabled(adev->pdev);
1850 }
1851 
1852 /* if we get transitioned to only one device, take VGA back */
1853 /**
1854  * amdgpu_device_vga_set_decode - enable/disable vga decode
1855  *
1856  * @pdev: PCI device pointer
1857  * @state: enable/disable vga decode
1858  *
1859  * Enable/disable vga decode (all asics).
1860  * Returns VGA resource flags.
1861  */
1862 static unsigned int amdgpu_device_vga_set_decode(struct pci_dev *pdev,
1863 		bool state)
1864 {
1865 	struct amdgpu_device *adev = drm_to_adev(pci_get_drvdata(pdev));
1866 
1867 	amdgpu_asic_set_vga_state(adev, state);
1868 	if (state)
1869 		return VGA_RSRC_LEGACY_IO | VGA_RSRC_LEGACY_MEM |
1870 		       VGA_RSRC_NORMAL_IO | VGA_RSRC_NORMAL_MEM;
1871 	else
1872 		return VGA_RSRC_NORMAL_IO | VGA_RSRC_NORMAL_MEM;
1873 }
1874 
1875 /**
1876  * amdgpu_device_check_block_size - validate the vm block size
1877  *
1878  * @adev: amdgpu_device pointer
1879  *
1880  * Validates the vm block size specified via module parameter.
1881  * The vm block size defines number of bits in page table versus page directory,
1882  * a page is 4KB so we have 12 bits offset, minimum 9 bits in the
1883  * page table and the remaining bits are in the page directory.
1884  */
1885 static void amdgpu_device_check_block_size(struct amdgpu_device *adev)
1886 {
1887 	/* defines number of bits in page table versus page directory,
1888 	 * a page is 4KB so we have 12 bits offset, minimum 9 bits in the
1889 	 * page table and the remaining bits are in the page directory
1890 	 */
1891 	if (amdgpu_vm_block_size == -1)
1892 		return;
1893 
1894 	if (amdgpu_vm_block_size < 9) {
1895 		dev_warn(adev->dev, "VM page table size (%d) too small\n",
1896 			 amdgpu_vm_block_size);
1897 		amdgpu_vm_block_size = -1;
1898 	}
1899 }
1900 
1901 /**
1902  * amdgpu_device_check_vm_size - validate the vm size
1903  *
1904  * @adev: amdgpu_device pointer
1905  *
1906  * Validates the vm size in GB specified via module parameter.
1907  * The VM size is the size of the GPU virtual memory space in GB.
1908  */
1909 static void amdgpu_device_check_vm_size(struct amdgpu_device *adev)
1910 {
1911 	/* no need to check the default value */
1912 	if (amdgpu_vm_size == -1)
1913 		return;
1914 
1915 	if (amdgpu_vm_size < 1) {
1916 		dev_warn(adev->dev, "VM size (%d) too small, min is 1GB\n",
1917 			 amdgpu_vm_size);
1918 		amdgpu_vm_size = -1;
1919 	}
1920 }
1921 
1922 static void amdgpu_device_check_smu_prv_buffer_size(struct amdgpu_device *adev)
1923 {
1924 	struct sysinfo si;
1925 	bool is_os_64 = (sizeof(void *) == 8);
1926 	uint64_t total_memory;
1927 	uint64_t dram_size_seven_GB = 0x1B8000000;
1928 	uint64_t dram_size_three_GB = 0xB8000000;
1929 
1930 	if (amdgpu_smu_memory_pool_size == 0)
1931 		return;
1932 
1933 	if (!is_os_64) {
1934 		DRM_WARN("Not 64-bit OS, feature not supported\n");
1935 		goto def_value;
1936 	}
1937 	si_meminfo(&si);
1938 	total_memory = (uint64_t)si.totalram * si.mem_unit;
1939 
1940 	if ((amdgpu_smu_memory_pool_size == 1) ||
1941 		(amdgpu_smu_memory_pool_size == 2)) {
1942 		if (total_memory < dram_size_three_GB)
1943 			goto def_value1;
1944 	} else if ((amdgpu_smu_memory_pool_size == 4) ||
1945 		(amdgpu_smu_memory_pool_size == 8)) {
1946 		if (total_memory < dram_size_seven_GB)
1947 			goto def_value1;
1948 	} else {
1949 		DRM_WARN("Smu memory pool size not supported\n");
1950 		goto def_value;
1951 	}
1952 	adev->pm.smu_prv_buffer_size = amdgpu_smu_memory_pool_size << 28;
1953 
1954 	return;
1955 
1956 def_value1:
1957 	DRM_WARN("No enough system memory\n");
1958 def_value:
1959 	adev->pm.smu_prv_buffer_size = 0;
1960 }
1961 
1962 static int amdgpu_device_init_apu_flags(struct amdgpu_device *adev)
1963 {
1964 	if (!(adev->flags & AMD_IS_APU) ||
1965 	    adev->asic_type < CHIP_RAVEN)
1966 		return 0;
1967 
1968 	switch (adev->asic_type) {
1969 	case CHIP_RAVEN:
1970 		if (adev->pdev->device == 0x15dd)
1971 			adev->apu_flags |= AMD_APU_IS_RAVEN;
1972 		if (adev->pdev->device == 0x15d8)
1973 			adev->apu_flags |= AMD_APU_IS_PICASSO;
1974 		break;
1975 	case CHIP_RENOIR:
1976 		if ((adev->pdev->device == 0x1636) ||
1977 		    (adev->pdev->device == 0x164c))
1978 			adev->apu_flags |= AMD_APU_IS_RENOIR;
1979 		else
1980 			adev->apu_flags |= AMD_APU_IS_GREEN_SARDINE;
1981 		break;
1982 	case CHIP_VANGOGH:
1983 		adev->apu_flags |= AMD_APU_IS_VANGOGH;
1984 		break;
1985 	case CHIP_YELLOW_CARP:
1986 		break;
1987 	case CHIP_CYAN_SKILLFISH:
1988 		if ((adev->pdev->device == 0x13FE) ||
1989 		    (adev->pdev->device == 0x143F))
1990 			adev->apu_flags |= AMD_APU_IS_CYAN_SKILLFISH2;
1991 		break;
1992 	default:
1993 		break;
1994 	}
1995 
1996 	return 0;
1997 }
1998 
1999 /**
2000  * amdgpu_device_check_arguments - validate module params
2001  *
2002  * @adev: amdgpu_device pointer
2003  *
2004  * Validates certain module parameters and updates
2005  * the associated values used by the driver (all asics).
2006  */
2007 static int amdgpu_device_check_arguments(struct amdgpu_device *adev)
2008 {
2009 	int i;
2010 
2011 	if (amdgpu_sched_jobs < 4) {
2012 		dev_warn(adev->dev, "sched jobs (%d) must be at least 4\n",
2013 			 amdgpu_sched_jobs);
2014 		amdgpu_sched_jobs = 4;
2015 	} else if (!is_power_of_2(amdgpu_sched_jobs)) {
2016 		dev_warn(adev->dev, "sched jobs (%d) must be a power of 2\n",
2017 			 amdgpu_sched_jobs);
2018 		amdgpu_sched_jobs = roundup_pow_of_two(amdgpu_sched_jobs);
2019 	}
2020 
2021 	if (amdgpu_gart_size != -1 && amdgpu_gart_size < 32) {
2022 		/* gart size must be greater or equal to 32M */
2023 		dev_warn(adev->dev, "gart size (%d) too small\n",
2024 			 amdgpu_gart_size);
2025 		amdgpu_gart_size = -1;
2026 	}
2027 
2028 	if (amdgpu_gtt_size != -1 && amdgpu_gtt_size < 32) {
2029 		/* gtt size must be greater or equal to 32M */
2030 		dev_warn(adev->dev, "gtt size (%d) too small\n",
2031 				 amdgpu_gtt_size);
2032 		amdgpu_gtt_size = -1;
2033 	}
2034 
2035 	/* valid range is between 4 and 9 inclusive */
2036 	if (amdgpu_vm_fragment_size != -1 &&
2037 	    (amdgpu_vm_fragment_size > 9 || amdgpu_vm_fragment_size < 4)) {
2038 		dev_warn(adev->dev, "valid range is between 4 and 9\n");
2039 		amdgpu_vm_fragment_size = -1;
2040 	}
2041 
2042 	if (amdgpu_sched_hw_submission < 2) {
2043 		dev_warn(adev->dev, "sched hw submission jobs (%d) must be at least 2\n",
2044 			 amdgpu_sched_hw_submission);
2045 		amdgpu_sched_hw_submission = 2;
2046 	} else if (!is_power_of_2(amdgpu_sched_hw_submission)) {
2047 		dev_warn(adev->dev, "sched hw submission jobs (%d) must be a power of 2\n",
2048 			 amdgpu_sched_hw_submission);
2049 		amdgpu_sched_hw_submission = roundup_pow_of_two(amdgpu_sched_hw_submission);
2050 	}
2051 
2052 	if (amdgpu_reset_method < -1 || amdgpu_reset_method > 4) {
2053 		dev_warn(adev->dev, "invalid option for reset method, reverting to default\n");
2054 		amdgpu_reset_method = -1;
2055 	}
2056 
2057 	amdgpu_device_check_smu_prv_buffer_size(adev);
2058 
2059 	amdgpu_device_check_vm_size(adev);
2060 
2061 	amdgpu_device_check_block_size(adev);
2062 
2063 	adev->firmware.load_type = amdgpu_ucode_get_load_type(adev, amdgpu_fw_load_type);
2064 
2065 	for (i = 0; i < MAX_XCP; i++)
2066 		adev->enforce_isolation[i] = !!enforce_isolation;
2067 
2068 	return 0;
2069 }
2070 
2071 /**
2072  * amdgpu_switcheroo_set_state - set switcheroo state
2073  *
2074  * @pdev: pci dev pointer
2075  * @state: vga_switcheroo state
2076  *
2077  * Callback for the switcheroo driver.  Suspends or resumes
2078  * the asics before or after it is powered up using ACPI methods.
2079  */
2080 static void amdgpu_switcheroo_set_state(struct pci_dev *pdev,
2081 					enum vga_switcheroo_state state)
2082 {
2083 	struct drm_device *dev = pci_get_drvdata(pdev);
2084 	int r;
2085 
2086 	if (amdgpu_device_supports_px(dev) && state == VGA_SWITCHEROO_OFF)
2087 		return;
2088 
2089 	if (state == VGA_SWITCHEROO_ON) {
2090 		pr_info("switched on\n");
2091 		/* don't suspend or resume card normally */
2092 		dev->switch_power_state = DRM_SWITCH_POWER_CHANGING;
2093 
2094 		pci_set_power_state(pdev, PCI_D0);
2095 		amdgpu_device_load_pci_state(pdev);
2096 		r = pci_enable_device(pdev);
2097 		if (r)
2098 			DRM_WARN("pci_enable_device failed (%d)\n", r);
2099 		amdgpu_device_resume(dev, true);
2100 
2101 		dev->switch_power_state = DRM_SWITCH_POWER_ON;
2102 	} else {
2103 		pr_info("switched off\n");
2104 		dev->switch_power_state = DRM_SWITCH_POWER_CHANGING;
2105 		amdgpu_device_prepare(dev);
2106 		amdgpu_device_suspend(dev, true);
2107 		amdgpu_device_cache_pci_state(pdev);
2108 		/* Shut down the device */
2109 		pci_disable_device(pdev);
2110 		pci_set_power_state(pdev, PCI_D3cold);
2111 		dev->switch_power_state = DRM_SWITCH_POWER_OFF;
2112 	}
2113 }
2114 
2115 /**
2116  * amdgpu_switcheroo_can_switch - see if switcheroo state can change
2117  *
2118  * @pdev: pci dev pointer
2119  *
2120  * Callback for the switcheroo driver.  Check of the switcheroo
2121  * state can be changed.
2122  * Returns true if the state can be changed, false if not.
2123  */
2124 static bool amdgpu_switcheroo_can_switch(struct pci_dev *pdev)
2125 {
2126 	struct drm_device *dev = pci_get_drvdata(pdev);
2127 
2128        /*
2129 	* FIXME: open_count is protected by drm_global_mutex but that would lead to
2130 	* locking inversion with the driver load path. And the access here is
2131 	* completely racy anyway. So don't bother with locking for now.
2132 	*/
2133 	return atomic_read(&dev->open_count) == 0;
2134 }
2135 
2136 static const struct vga_switcheroo_client_ops amdgpu_switcheroo_ops = {
2137 	.set_gpu_state = amdgpu_switcheroo_set_state,
2138 	.reprobe = NULL,
2139 	.can_switch = amdgpu_switcheroo_can_switch,
2140 };
2141 
2142 /**
2143  * amdgpu_device_ip_set_clockgating_state - set the CG state
2144  *
2145  * @dev: amdgpu_device pointer
2146  * @block_type: Type of hardware IP (SMU, GFX, UVD, etc.)
2147  * @state: clockgating state (gate or ungate)
2148  *
2149  * Sets the requested clockgating state for all instances of
2150  * the hardware IP specified.
2151  * Returns the error code from the last instance.
2152  */
2153 int amdgpu_device_ip_set_clockgating_state(void *dev,
2154 					   enum amd_ip_block_type block_type,
2155 					   enum amd_clockgating_state state)
2156 {
2157 	struct amdgpu_device *adev = dev;
2158 	int i, r = 0;
2159 
2160 	for (i = 0; i < adev->num_ip_blocks; i++) {
2161 		if (!adev->ip_blocks[i].status.valid)
2162 			continue;
2163 		if (adev->ip_blocks[i].version->type != block_type)
2164 			continue;
2165 		if (!adev->ip_blocks[i].version->funcs->set_clockgating_state)
2166 			continue;
2167 		r = adev->ip_blocks[i].version->funcs->set_clockgating_state(
2168 			(void *)adev, state);
2169 		if (r)
2170 			DRM_ERROR("set_clockgating_state of IP block <%s> failed %d\n",
2171 				  adev->ip_blocks[i].version->funcs->name, r);
2172 	}
2173 	return r;
2174 }
2175 
2176 /**
2177  * amdgpu_device_ip_set_powergating_state - set the PG state
2178  *
2179  * @dev: amdgpu_device pointer
2180  * @block_type: Type of hardware IP (SMU, GFX, UVD, etc.)
2181  * @state: powergating state (gate or ungate)
2182  *
2183  * Sets the requested powergating state for all instances of
2184  * the hardware IP specified.
2185  * Returns the error code from the last instance.
2186  */
2187 int amdgpu_device_ip_set_powergating_state(void *dev,
2188 					   enum amd_ip_block_type block_type,
2189 					   enum amd_powergating_state state)
2190 {
2191 	struct amdgpu_device *adev = dev;
2192 	int i, r = 0;
2193 
2194 	for (i = 0; i < adev->num_ip_blocks; i++) {
2195 		if (!adev->ip_blocks[i].status.valid)
2196 			continue;
2197 		if (adev->ip_blocks[i].version->type != block_type)
2198 			continue;
2199 		if (!adev->ip_blocks[i].version->funcs->set_powergating_state)
2200 			continue;
2201 		r = adev->ip_blocks[i].version->funcs->set_powergating_state(
2202 			(void *)adev, state);
2203 		if (r)
2204 			DRM_ERROR("set_powergating_state of IP block <%s> failed %d\n",
2205 				  adev->ip_blocks[i].version->funcs->name, r);
2206 	}
2207 	return r;
2208 }
2209 
2210 /**
2211  * amdgpu_device_ip_get_clockgating_state - get the CG state
2212  *
2213  * @adev: amdgpu_device pointer
2214  * @flags: clockgating feature flags
2215  *
2216  * Walks the list of IPs on the device and updates the clockgating
2217  * flags for each IP.
2218  * Updates @flags with the feature flags for each hardware IP where
2219  * clockgating is enabled.
2220  */
2221 void amdgpu_device_ip_get_clockgating_state(struct amdgpu_device *adev,
2222 					    u64 *flags)
2223 {
2224 	int i;
2225 
2226 	for (i = 0; i < adev->num_ip_blocks; i++) {
2227 		if (!adev->ip_blocks[i].status.valid)
2228 			continue;
2229 		if (adev->ip_blocks[i].version->funcs->get_clockgating_state)
2230 			adev->ip_blocks[i].version->funcs->get_clockgating_state((void *)adev, flags);
2231 	}
2232 }
2233 
2234 /**
2235  * amdgpu_device_ip_wait_for_idle - wait for idle
2236  *
2237  * @adev: amdgpu_device pointer
2238  * @block_type: Type of hardware IP (SMU, GFX, UVD, etc.)
2239  *
2240  * Waits for the request hardware IP to be idle.
2241  * Returns 0 for success or a negative error code on failure.
2242  */
2243 int amdgpu_device_ip_wait_for_idle(struct amdgpu_device *adev,
2244 				   enum amd_ip_block_type block_type)
2245 {
2246 	int i, r;
2247 
2248 	for (i = 0; i < adev->num_ip_blocks; i++) {
2249 		if (!adev->ip_blocks[i].status.valid)
2250 			continue;
2251 		if (adev->ip_blocks[i].version->type == block_type) {
2252 			if (adev->ip_blocks[i].version->funcs->wait_for_idle) {
2253 				r = adev->ip_blocks[i].version->funcs->wait_for_idle(
2254 								&adev->ip_blocks[i]);
2255 				if (r)
2256 					return r;
2257 			}
2258 			break;
2259 		}
2260 	}
2261 	return 0;
2262 
2263 }
2264 
2265 /**
2266  * amdgpu_device_ip_is_valid - is the hardware IP enabled
2267  *
2268  * @adev: amdgpu_device pointer
2269  * @block_type: Type of hardware IP (SMU, GFX, UVD, etc.)
2270  *
2271  * Check if the hardware IP is enable or not.
2272  * Returns true if it the IP is enable, false if not.
2273  */
2274 bool amdgpu_device_ip_is_valid(struct amdgpu_device *adev,
2275 			       enum amd_ip_block_type block_type)
2276 {
2277 	int i;
2278 
2279 	for (i = 0; i < adev->num_ip_blocks; i++) {
2280 		if (adev->ip_blocks[i].version->type == block_type)
2281 			return adev->ip_blocks[i].status.valid;
2282 	}
2283 	return false;
2284 
2285 }
2286 
2287 /**
2288  * amdgpu_device_ip_get_ip_block - get a hw IP pointer
2289  *
2290  * @adev: amdgpu_device pointer
2291  * @type: Type of hardware IP (SMU, GFX, UVD, etc.)
2292  *
2293  * Returns a pointer to the hardware IP block structure
2294  * if it exists for the asic, otherwise NULL.
2295  */
2296 struct amdgpu_ip_block *
2297 amdgpu_device_ip_get_ip_block(struct amdgpu_device *adev,
2298 			      enum amd_ip_block_type type)
2299 {
2300 	int i;
2301 
2302 	for (i = 0; i < adev->num_ip_blocks; i++)
2303 		if (adev->ip_blocks[i].version->type == type)
2304 			return &adev->ip_blocks[i];
2305 
2306 	return NULL;
2307 }
2308 
2309 /**
2310  * amdgpu_device_ip_block_version_cmp
2311  *
2312  * @adev: amdgpu_device pointer
2313  * @type: enum amd_ip_block_type
2314  * @major: major version
2315  * @minor: minor version
2316  *
2317  * return 0 if equal or greater
2318  * return 1 if smaller or the ip_block doesn't exist
2319  */
2320 int amdgpu_device_ip_block_version_cmp(struct amdgpu_device *adev,
2321 				       enum amd_ip_block_type type,
2322 				       u32 major, u32 minor)
2323 {
2324 	struct amdgpu_ip_block *ip_block = amdgpu_device_ip_get_ip_block(adev, type);
2325 
2326 	if (ip_block && ((ip_block->version->major > major) ||
2327 			((ip_block->version->major == major) &&
2328 			(ip_block->version->minor >= minor))))
2329 		return 0;
2330 
2331 	return 1;
2332 }
2333 
2334 /**
2335  * amdgpu_device_ip_block_add
2336  *
2337  * @adev: amdgpu_device pointer
2338  * @ip_block_version: pointer to the IP to add
2339  *
2340  * Adds the IP block driver information to the collection of IPs
2341  * on the asic.
2342  */
2343 int amdgpu_device_ip_block_add(struct amdgpu_device *adev,
2344 			       const struct amdgpu_ip_block_version *ip_block_version)
2345 {
2346 	if (!ip_block_version)
2347 		return -EINVAL;
2348 
2349 	switch (ip_block_version->type) {
2350 	case AMD_IP_BLOCK_TYPE_VCN:
2351 		if (adev->harvest_ip_mask & AMD_HARVEST_IP_VCN_MASK)
2352 			return 0;
2353 		break;
2354 	case AMD_IP_BLOCK_TYPE_JPEG:
2355 		if (adev->harvest_ip_mask & AMD_HARVEST_IP_JPEG_MASK)
2356 			return 0;
2357 		break;
2358 	default:
2359 		break;
2360 	}
2361 
2362 	DRM_INFO("add ip block number %d <%s>\n", adev->num_ip_blocks,
2363 		  ip_block_version->funcs->name);
2364 
2365 	adev->ip_blocks[adev->num_ip_blocks].adev = adev;
2366 
2367 	adev->ip_blocks[adev->num_ip_blocks++].version = ip_block_version;
2368 
2369 	return 0;
2370 }
2371 
2372 /**
2373  * amdgpu_device_enable_virtual_display - enable virtual display feature
2374  *
2375  * @adev: amdgpu_device pointer
2376  *
2377  * Enabled the virtual display feature if the user has enabled it via
2378  * the module parameter virtual_display.  This feature provides a virtual
2379  * display hardware on headless boards or in virtualized environments.
2380  * This function parses and validates the configuration string specified by
2381  * the user and configues the virtual display configuration (number of
2382  * virtual connectors, crtcs, etc.) specified.
2383  */
2384 static void amdgpu_device_enable_virtual_display(struct amdgpu_device *adev)
2385 {
2386 	adev->enable_virtual_display = false;
2387 
2388 	if (amdgpu_virtual_display) {
2389 		const char *pci_address_name = pci_name(adev->pdev);
2390 		char *pciaddstr, *pciaddstr_tmp, *pciaddname_tmp, *pciaddname;
2391 
2392 		pciaddstr = kstrdup(amdgpu_virtual_display, GFP_KERNEL);
2393 		pciaddstr_tmp = pciaddstr;
2394 		while ((pciaddname_tmp = strsep(&pciaddstr_tmp, ";"))) {
2395 			pciaddname = strsep(&pciaddname_tmp, ",");
2396 			if (!strcmp("all", pciaddname)
2397 			    || !strcmp(pci_address_name, pciaddname)) {
2398 				long num_crtc;
2399 				int res = -1;
2400 
2401 				adev->enable_virtual_display = true;
2402 
2403 				if (pciaddname_tmp)
2404 					res = kstrtol(pciaddname_tmp, 10,
2405 						      &num_crtc);
2406 
2407 				if (!res) {
2408 					if (num_crtc < 1)
2409 						num_crtc = 1;
2410 					if (num_crtc > 6)
2411 						num_crtc = 6;
2412 					adev->mode_info.num_crtc = num_crtc;
2413 				} else {
2414 					adev->mode_info.num_crtc = 1;
2415 				}
2416 				break;
2417 			}
2418 		}
2419 
2420 		DRM_INFO("virtual display string:%s, %s:virtual_display:%d, num_crtc:%d\n",
2421 			 amdgpu_virtual_display, pci_address_name,
2422 			 adev->enable_virtual_display, adev->mode_info.num_crtc);
2423 
2424 		kfree(pciaddstr);
2425 	}
2426 }
2427 
2428 void amdgpu_device_set_sriov_virtual_display(struct amdgpu_device *adev)
2429 {
2430 	if (amdgpu_sriov_vf(adev) && !adev->enable_virtual_display) {
2431 		adev->mode_info.num_crtc = 1;
2432 		adev->enable_virtual_display = true;
2433 		DRM_INFO("virtual_display:%d, num_crtc:%d\n",
2434 			 adev->enable_virtual_display, adev->mode_info.num_crtc);
2435 	}
2436 }
2437 
2438 /**
2439  * amdgpu_device_parse_gpu_info_fw - parse gpu info firmware
2440  *
2441  * @adev: amdgpu_device pointer
2442  *
2443  * Parses the asic configuration parameters specified in the gpu info
2444  * firmware and makes them availale to the driver for use in configuring
2445  * the asic.
2446  * Returns 0 on success, -EINVAL on failure.
2447  */
2448 static int amdgpu_device_parse_gpu_info_fw(struct amdgpu_device *adev)
2449 {
2450 	const char *chip_name;
2451 	int err;
2452 	const struct gpu_info_firmware_header_v1_0 *hdr;
2453 
2454 	adev->firmware.gpu_info_fw = NULL;
2455 
2456 	if (adev->mman.discovery_bin)
2457 		return 0;
2458 
2459 	switch (adev->asic_type) {
2460 	default:
2461 		return 0;
2462 	case CHIP_VEGA10:
2463 		chip_name = "vega10";
2464 		break;
2465 	case CHIP_VEGA12:
2466 		chip_name = "vega12";
2467 		break;
2468 	case CHIP_RAVEN:
2469 		if (adev->apu_flags & AMD_APU_IS_RAVEN2)
2470 			chip_name = "raven2";
2471 		else if (adev->apu_flags & AMD_APU_IS_PICASSO)
2472 			chip_name = "picasso";
2473 		else
2474 			chip_name = "raven";
2475 		break;
2476 	case CHIP_ARCTURUS:
2477 		chip_name = "arcturus";
2478 		break;
2479 	case CHIP_NAVI12:
2480 		chip_name = "navi12";
2481 		break;
2482 	}
2483 
2484 	err = amdgpu_ucode_request(adev, &adev->firmware.gpu_info_fw,
2485 				   "amdgpu/%s_gpu_info.bin", chip_name);
2486 	if (err) {
2487 		dev_err(adev->dev,
2488 			"Failed to get gpu_info firmware \"%s_gpu_info.bin\"\n",
2489 			chip_name);
2490 		goto out;
2491 	}
2492 
2493 	hdr = (const struct gpu_info_firmware_header_v1_0 *)adev->firmware.gpu_info_fw->data;
2494 	amdgpu_ucode_print_gpu_info_hdr(&hdr->header);
2495 
2496 	switch (hdr->version_major) {
2497 	case 1:
2498 	{
2499 		const struct gpu_info_firmware_v1_0 *gpu_info_fw =
2500 			(const struct gpu_info_firmware_v1_0 *)(adev->firmware.gpu_info_fw->data +
2501 								le32_to_cpu(hdr->header.ucode_array_offset_bytes));
2502 
2503 		/*
2504 		 * Should be droped when DAL no longer needs it.
2505 		 */
2506 		if (adev->asic_type == CHIP_NAVI12)
2507 			goto parse_soc_bounding_box;
2508 
2509 		adev->gfx.config.max_shader_engines = le32_to_cpu(gpu_info_fw->gc_num_se);
2510 		adev->gfx.config.max_cu_per_sh = le32_to_cpu(gpu_info_fw->gc_num_cu_per_sh);
2511 		adev->gfx.config.max_sh_per_se = le32_to_cpu(gpu_info_fw->gc_num_sh_per_se);
2512 		adev->gfx.config.max_backends_per_se = le32_to_cpu(gpu_info_fw->gc_num_rb_per_se);
2513 		adev->gfx.config.max_texture_channel_caches =
2514 			le32_to_cpu(gpu_info_fw->gc_num_tccs);
2515 		adev->gfx.config.max_gprs = le32_to_cpu(gpu_info_fw->gc_num_gprs);
2516 		adev->gfx.config.max_gs_threads = le32_to_cpu(gpu_info_fw->gc_num_max_gs_thds);
2517 		adev->gfx.config.gs_vgt_table_depth = le32_to_cpu(gpu_info_fw->gc_gs_table_depth);
2518 		adev->gfx.config.gs_prim_buffer_depth = le32_to_cpu(gpu_info_fw->gc_gsprim_buff_depth);
2519 		adev->gfx.config.double_offchip_lds_buf =
2520 			le32_to_cpu(gpu_info_fw->gc_double_offchip_lds_buffer);
2521 		adev->gfx.cu_info.wave_front_size = le32_to_cpu(gpu_info_fw->gc_wave_size);
2522 		adev->gfx.cu_info.max_waves_per_simd =
2523 			le32_to_cpu(gpu_info_fw->gc_max_waves_per_simd);
2524 		adev->gfx.cu_info.max_scratch_slots_per_cu =
2525 			le32_to_cpu(gpu_info_fw->gc_max_scratch_slots_per_cu);
2526 		adev->gfx.cu_info.lds_size = le32_to_cpu(gpu_info_fw->gc_lds_size);
2527 		if (hdr->version_minor >= 1) {
2528 			const struct gpu_info_firmware_v1_1 *gpu_info_fw =
2529 				(const struct gpu_info_firmware_v1_1 *)(adev->firmware.gpu_info_fw->data +
2530 									le32_to_cpu(hdr->header.ucode_array_offset_bytes));
2531 			adev->gfx.config.num_sc_per_sh =
2532 				le32_to_cpu(gpu_info_fw->num_sc_per_sh);
2533 			adev->gfx.config.num_packer_per_sc =
2534 				le32_to_cpu(gpu_info_fw->num_packer_per_sc);
2535 		}
2536 
2537 parse_soc_bounding_box:
2538 		/*
2539 		 * soc bounding box info is not integrated in disocovery table,
2540 		 * we always need to parse it from gpu info firmware if needed.
2541 		 */
2542 		if (hdr->version_minor == 2) {
2543 			const struct gpu_info_firmware_v1_2 *gpu_info_fw =
2544 				(const struct gpu_info_firmware_v1_2 *)(adev->firmware.gpu_info_fw->data +
2545 									le32_to_cpu(hdr->header.ucode_array_offset_bytes));
2546 			adev->dm.soc_bounding_box = &gpu_info_fw->soc_bounding_box;
2547 		}
2548 		break;
2549 	}
2550 	default:
2551 		dev_err(adev->dev,
2552 			"Unsupported gpu_info table %d\n", hdr->header.ucode_version);
2553 		err = -EINVAL;
2554 		goto out;
2555 	}
2556 out:
2557 	return err;
2558 }
2559 
2560 /**
2561  * amdgpu_device_ip_early_init - run early init for hardware IPs
2562  *
2563  * @adev: amdgpu_device pointer
2564  *
2565  * Early initialization pass for hardware IPs.  The hardware IPs that make
2566  * up each asic are discovered each IP's early_init callback is run.  This
2567  * is the first stage in initializing the asic.
2568  * Returns 0 on success, negative error code on failure.
2569  */
2570 static int amdgpu_device_ip_early_init(struct amdgpu_device *adev)
2571 {
2572 	struct amdgpu_ip_block *ip_block;
2573 	struct pci_dev *parent;
2574 	int i, r;
2575 	bool total;
2576 
2577 	amdgpu_device_enable_virtual_display(adev);
2578 
2579 	if (amdgpu_sriov_vf(adev)) {
2580 		r = amdgpu_virt_request_full_gpu(adev, true);
2581 		if (r)
2582 			return r;
2583 	}
2584 
2585 	switch (adev->asic_type) {
2586 #ifdef CONFIG_DRM_AMDGPU_SI
2587 	case CHIP_VERDE:
2588 	case CHIP_TAHITI:
2589 	case CHIP_PITCAIRN:
2590 	case CHIP_OLAND:
2591 	case CHIP_HAINAN:
2592 		adev->family = AMDGPU_FAMILY_SI;
2593 		r = si_set_ip_blocks(adev);
2594 		if (r)
2595 			return r;
2596 		break;
2597 #endif
2598 #ifdef CONFIG_DRM_AMDGPU_CIK
2599 	case CHIP_BONAIRE:
2600 	case CHIP_HAWAII:
2601 	case CHIP_KAVERI:
2602 	case CHIP_KABINI:
2603 	case CHIP_MULLINS:
2604 		if (adev->flags & AMD_IS_APU)
2605 			adev->family = AMDGPU_FAMILY_KV;
2606 		else
2607 			adev->family = AMDGPU_FAMILY_CI;
2608 
2609 		r = cik_set_ip_blocks(adev);
2610 		if (r)
2611 			return r;
2612 		break;
2613 #endif
2614 	case CHIP_TOPAZ:
2615 	case CHIP_TONGA:
2616 	case CHIP_FIJI:
2617 	case CHIP_POLARIS10:
2618 	case CHIP_POLARIS11:
2619 	case CHIP_POLARIS12:
2620 	case CHIP_VEGAM:
2621 	case CHIP_CARRIZO:
2622 	case CHIP_STONEY:
2623 		if (adev->flags & AMD_IS_APU)
2624 			adev->family = AMDGPU_FAMILY_CZ;
2625 		else
2626 			adev->family = AMDGPU_FAMILY_VI;
2627 
2628 		r = vi_set_ip_blocks(adev);
2629 		if (r)
2630 			return r;
2631 		break;
2632 	default:
2633 		r = amdgpu_discovery_set_ip_blocks(adev);
2634 		if (r)
2635 			return r;
2636 		break;
2637 	}
2638 
2639 	if (amdgpu_has_atpx() &&
2640 	    (amdgpu_is_atpx_hybrid() ||
2641 	     amdgpu_has_atpx_dgpu_power_cntl()) &&
2642 	    ((adev->flags & AMD_IS_APU) == 0) &&
2643 	    !dev_is_removable(&adev->pdev->dev))
2644 		adev->flags |= AMD_IS_PX;
2645 
2646 	if (!(adev->flags & AMD_IS_APU)) {
2647 		parent = pcie_find_root_port(adev->pdev);
2648 		adev->has_pr3 = parent ? pci_pr3_present(parent) : false;
2649 	}
2650 
2651 
2652 	adev->pm.pp_feature = amdgpu_pp_feature_mask;
2653 	if (amdgpu_sriov_vf(adev) || sched_policy == KFD_SCHED_POLICY_NO_HWS)
2654 		adev->pm.pp_feature &= ~PP_GFXOFF_MASK;
2655 	if (amdgpu_sriov_vf(adev) && adev->asic_type == CHIP_SIENNA_CICHLID)
2656 		adev->pm.pp_feature &= ~PP_OVERDRIVE_MASK;
2657 	if (!amdgpu_device_pcie_dynamic_switching_supported(adev))
2658 		adev->pm.pp_feature &= ~PP_PCIE_DPM_MASK;
2659 
2660 	total = true;
2661 	for (i = 0; i < adev->num_ip_blocks; i++) {
2662 		ip_block = &adev->ip_blocks[i];
2663 
2664 		if ((amdgpu_ip_block_mask & (1 << i)) == 0) {
2665 			DRM_WARN("disabled ip block: %d <%s>\n",
2666 				  i, adev->ip_blocks[i].version->funcs->name);
2667 			adev->ip_blocks[i].status.valid = false;
2668 		} else if (ip_block->version->funcs->early_init) {
2669 			r = ip_block->version->funcs->early_init(ip_block);
2670 			if (r == -ENOENT) {
2671 				adev->ip_blocks[i].status.valid = false;
2672 			} else if (r) {
2673 				DRM_ERROR("early_init of IP block <%s> failed %d\n",
2674 					  adev->ip_blocks[i].version->funcs->name, r);
2675 				total = false;
2676 			} else {
2677 				adev->ip_blocks[i].status.valid = true;
2678 			}
2679 		} else {
2680 			adev->ip_blocks[i].status.valid = true;
2681 		}
2682 		/* get the vbios after the asic_funcs are set up */
2683 		if (adev->ip_blocks[i].version->type == AMD_IP_BLOCK_TYPE_COMMON) {
2684 			r = amdgpu_device_parse_gpu_info_fw(adev);
2685 			if (r)
2686 				return r;
2687 
2688 			/* Read BIOS */
2689 			if (amdgpu_device_read_bios(adev)) {
2690 				if (!amdgpu_get_bios(adev))
2691 					return -EINVAL;
2692 
2693 				r = amdgpu_atombios_init(adev);
2694 				if (r) {
2695 					dev_err(adev->dev, "amdgpu_atombios_init failed\n");
2696 					amdgpu_vf_error_put(adev, AMDGIM_ERROR_VF_ATOMBIOS_INIT_FAIL, 0, 0);
2697 					return r;
2698 				}
2699 			}
2700 
2701 			/*get pf2vf msg info at it's earliest time*/
2702 			if (amdgpu_sriov_vf(adev))
2703 				amdgpu_virt_init_data_exchange(adev);
2704 
2705 		}
2706 	}
2707 	if (!total)
2708 		return -ENODEV;
2709 
2710 	ip_block = amdgpu_device_ip_get_ip_block(adev, AMD_IP_BLOCK_TYPE_GFX);
2711 	if (ip_block->status.valid != false)
2712 		amdgpu_amdkfd_device_probe(adev);
2713 
2714 	adev->cg_flags &= amdgpu_cg_mask;
2715 	adev->pg_flags &= amdgpu_pg_mask;
2716 
2717 	return 0;
2718 }
2719 
2720 static int amdgpu_device_ip_hw_init_phase1(struct amdgpu_device *adev)
2721 {
2722 	int i, r;
2723 
2724 	for (i = 0; i < adev->num_ip_blocks; i++) {
2725 		if (!adev->ip_blocks[i].status.sw)
2726 			continue;
2727 		if (adev->ip_blocks[i].status.hw)
2728 			continue;
2729 		if (!amdgpu_ip_member_of_hwini(
2730 			    adev, adev->ip_blocks[i].version->type))
2731 			continue;
2732 		if (adev->ip_blocks[i].version->type == AMD_IP_BLOCK_TYPE_COMMON ||
2733 		    (amdgpu_sriov_vf(adev) && (adev->ip_blocks[i].version->type == AMD_IP_BLOCK_TYPE_PSP)) ||
2734 		    adev->ip_blocks[i].version->type == AMD_IP_BLOCK_TYPE_IH) {
2735 			r = adev->ip_blocks[i].version->funcs->hw_init(&adev->ip_blocks[i]);
2736 			if (r) {
2737 				DRM_ERROR("hw_init of IP block <%s> failed %d\n",
2738 					  adev->ip_blocks[i].version->funcs->name, r);
2739 				return r;
2740 			}
2741 			adev->ip_blocks[i].status.hw = true;
2742 		}
2743 	}
2744 
2745 	return 0;
2746 }
2747 
2748 static int amdgpu_device_ip_hw_init_phase2(struct amdgpu_device *adev)
2749 {
2750 	int i, r;
2751 
2752 	for (i = 0; i < adev->num_ip_blocks; i++) {
2753 		if (!adev->ip_blocks[i].status.sw)
2754 			continue;
2755 		if (adev->ip_blocks[i].status.hw)
2756 			continue;
2757 		if (!amdgpu_ip_member_of_hwini(
2758 			    adev, adev->ip_blocks[i].version->type))
2759 			continue;
2760 		r = adev->ip_blocks[i].version->funcs->hw_init(&adev->ip_blocks[i]);
2761 		if (r) {
2762 			DRM_ERROR("hw_init of IP block <%s> failed %d\n",
2763 				  adev->ip_blocks[i].version->funcs->name, r);
2764 			return r;
2765 		}
2766 		adev->ip_blocks[i].status.hw = true;
2767 	}
2768 
2769 	return 0;
2770 }
2771 
2772 static int amdgpu_device_fw_loading(struct amdgpu_device *adev)
2773 {
2774 	int r = 0;
2775 	int i;
2776 	uint32_t smu_version;
2777 
2778 	if (adev->asic_type >= CHIP_VEGA10) {
2779 		for (i = 0; i < adev->num_ip_blocks; i++) {
2780 			if (adev->ip_blocks[i].version->type != AMD_IP_BLOCK_TYPE_PSP)
2781 				continue;
2782 
2783 			if (!amdgpu_ip_member_of_hwini(adev,
2784 						       AMD_IP_BLOCK_TYPE_PSP))
2785 				break;
2786 
2787 			if (!adev->ip_blocks[i].status.sw)
2788 				continue;
2789 
2790 			/* no need to do the fw loading again if already done*/
2791 			if (adev->ip_blocks[i].status.hw == true)
2792 				break;
2793 
2794 			if (amdgpu_in_reset(adev) || adev->in_suspend) {
2795 				r = amdgpu_ip_block_resume(&adev->ip_blocks[i]);
2796 				if (r)
2797 					return r;
2798 			} else {
2799 				r = adev->ip_blocks[i].version->funcs->hw_init(&adev->ip_blocks[i]);
2800 				if (r) {
2801 					DRM_ERROR("hw_init of IP block <%s> failed %d\n",
2802 							  adev->ip_blocks[i].version->funcs->name, r);
2803 					return r;
2804 				}
2805 				adev->ip_blocks[i].status.hw = true;
2806 			}
2807 			break;
2808 		}
2809 	}
2810 
2811 	if (!amdgpu_sriov_vf(adev) || adev->asic_type == CHIP_TONGA)
2812 		r = amdgpu_pm_load_smu_firmware(adev, &smu_version);
2813 
2814 	return r;
2815 }
2816 
2817 static int amdgpu_device_init_schedulers(struct amdgpu_device *adev)
2818 {
2819 	long timeout;
2820 	int r, i;
2821 
2822 	for (i = 0; i < AMDGPU_MAX_RINGS; ++i) {
2823 		struct amdgpu_ring *ring = adev->rings[i];
2824 
2825 		/* No need to setup the GPU scheduler for rings that don't need it */
2826 		if (!ring || ring->no_scheduler)
2827 			continue;
2828 
2829 		switch (ring->funcs->type) {
2830 		case AMDGPU_RING_TYPE_GFX:
2831 			timeout = adev->gfx_timeout;
2832 			break;
2833 		case AMDGPU_RING_TYPE_COMPUTE:
2834 			timeout = adev->compute_timeout;
2835 			break;
2836 		case AMDGPU_RING_TYPE_SDMA:
2837 			timeout = adev->sdma_timeout;
2838 			break;
2839 		default:
2840 			timeout = adev->video_timeout;
2841 			break;
2842 		}
2843 
2844 		r = drm_sched_init(&ring->sched, &amdgpu_sched_ops, NULL,
2845 				   DRM_SCHED_PRIORITY_COUNT,
2846 				   ring->num_hw_submission, 0,
2847 				   timeout, adev->reset_domain->wq,
2848 				   ring->sched_score, ring->name,
2849 				   adev->dev);
2850 		if (r) {
2851 			DRM_ERROR("Failed to create scheduler on ring %s.\n",
2852 				  ring->name);
2853 			return r;
2854 		}
2855 		r = amdgpu_uvd_entity_init(adev, ring);
2856 		if (r) {
2857 			DRM_ERROR("Failed to create UVD scheduling entity on ring %s.\n",
2858 				  ring->name);
2859 			return r;
2860 		}
2861 		r = amdgpu_vce_entity_init(adev, ring);
2862 		if (r) {
2863 			DRM_ERROR("Failed to create VCE scheduling entity on ring %s.\n",
2864 				  ring->name);
2865 			return r;
2866 		}
2867 	}
2868 
2869 	amdgpu_xcp_update_partition_sched_list(adev);
2870 
2871 	return 0;
2872 }
2873 
2874 
2875 /**
2876  * amdgpu_device_ip_init - run init for hardware IPs
2877  *
2878  * @adev: amdgpu_device pointer
2879  *
2880  * Main initialization pass for hardware IPs.  The list of all the hardware
2881  * IPs that make up the asic is walked and the sw_init and hw_init callbacks
2882  * are run.  sw_init initializes the software state associated with each IP
2883  * and hw_init initializes the hardware associated with each IP.
2884  * Returns 0 on success, negative error code on failure.
2885  */
2886 static int amdgpu_device_ip_init(struct amdgpu_device *adev)
2887 {
2888 	bool init_badpage;
2889 	int i, r;
2890 
2891 	r = amdgpu_ras_init(adev);
2892 	if (r)
2893 		return r;
2894 
2895 	for (i = 0; i < adev->num_ip_blocks; i++) {
2896 		if (!adev->ip_blocks[i].status.valid)
2897 			continue;
2898 		if (adev->ip_blocks[i].version->funcs->sw_init) {
2899 			r = adev->ip_blocks[i].version->funcs->sw_init(&adev->ip_blocks[i]);
2900 			if (r) {
2901 				DRM_ERROR("sw_init of IP block <%s> failed %d\n",
2902 					  adev->ip_blocks[i].version->funcs->name, r);
2903 				goto init_failed;
2904 			}
2905 		}
2906 		adev->ip_blocks[i].status.sw = true;
2907 
2908 		if (!amdgpu_ip_member_of_hwini(
2909 			    adev, adev->ip_blocks[i].version->type))
2910 			continue;
2911 
2912 		if (adev->ip_blocks[i].version->type == AMD_IP_BLOCK_TYPE_COMMON) {
2913 			/* need to do common hw init early so everything is set up for gmc */
2914 			r = adev->ip_blocks[i].version->funcs->hw_init(&adev->ip_blocks[i]);
2915 			if (r) {
2916 				DRM_ERROR("hw_init %d failed %d\n", i, r);
2917 				goto init_failed;
2918 			}
2919 			adev->ip_blocks[i].status.hw = true;
2920 		} else if (adev->ip_blocks[i].version->type == AMD_IP_BLOCK_TYPE_GMC) {
2921 			/* need to do gmc hw init early so we can allocate gpu mem */
2922 			/* Try to reserve bad pages early */
2923 			if (amdgpu_sriov_vf(adev))
2924 				amdgpu_virt_exchange_data(adev);
2925 
2926 			r = amdgpu_device_mem_scratch_init(adev);
2927 			if (r) {
2928 				DRM_ERROR("amdgpu_mem_scratch_init failed %d\n", r);
2929 				goto init_failed;
2930 			}
2931 			r = adev->ip_blocks[i].version->funcs->hw_init(&adev->ip_blocks[i]);
2932 			if (r) {
2933 				DRM_ERROR("hw_init %d failed %d\n", i, r);
2934 				goto init_failed;
2935 			}
2936 			r = amdgpu_device_wb_init(adev);
2937 			if (r) {
2938 				DRM_ERROR("amdgpu_device_wb_init failed %d\n", r);
2939 				goto init_failed;
2940 			}
2941 			adev->ip_blocks[i].status.hw = true;
2942 
2943 			/* right after GMC hw init, we create CSA */
2944 			if (adev->gfx.mcbp) {
2945 				r = amdgpu_allocate_static_csa(adev, &adev->virt.csa_obj,
2946 							       AMDGPU_GEM_DOMAIN_VRAM |
2947 							       AMDGPU_GEM_DOMAIN_GTT,
2948 							       AMDGPU_CSA_SIZE);
2949 				if (r) {
2950 					DRM_ERROR("allocate CSA failed %d\n", r);
2951 					goto init_failed;
2952 				}
2953 			}
2954 
2955 			r = amdgpu_seq64_init(adev);
2956 			if (r) {
2957 				DRM_ERROR("allocate seq64 failed %d\n", r);
2958 				goto init_failed;
2959 			}
2960 		}
2961 	}
2962 
2963 	if (amdgpu_sriov_vf(adev))
2964 		amdgpu_virt_init_data_exchange(adev);
2965 
2966 	r = amdgpu_ib_pool_init(adev);
2967 	if (r) {
2968 		dev_err(adev->dev, "IB initialization failed (%d).\n", r);
2969 		amdgpu_vf_error_put(adev, AMDGIM_ERROR_VF_IB_INIT_FAIL, 0, r);
2970 		goto init_failed;
2971 	}
2972 
2973 	r = amdgpu_ucode_create_bo(adev); /* create ucode bo when sw_init complete*/
2974 	if (r)
2975 		goto init_failed;
2976 
2977 	r = amdgpu_device_ip_hw_init_phase1(adev);
2978 	if (r)
2979 		goto init_failed;
2980 
2981 	r = amdgpu_device_fw_loading(adev);
2982 	if (r)
2983 		goto init_failed;
2984 
2985 	r = amdgpu_device_ip_hw_init_phase2(adev);
2986 	if (r)
2987 		goto init_failed;
2988 
2989 	/*
2990 	 * retired pages will be loaded from eeprom and reserved here,
2991 	 * it should be called after amdgpu_device_ip_hw_init_phase2  since
2992 	 * for some ASICs the RAS EEPROM code relies on SMU fully functioning
2993 	 * for I2C communication which only true at this point.
2994 	 *
2995 	 * amdgpu_ras_recovery_init may fail, but the upper only cares the
2996 	 * failure from bad gpu situation and stop amdgpu init process
2997 	 * accordingly. For other failed cases, it will still release all
2998 	 * the resource and print error message, rather than returning one
2999 	 * negative value to upper level.
3000 	 *
3001 	 * Note: theoretically, this should be called before all vram allocations
3002 	 * to protect retired page from abusing
3003 	 */
3004 	init_badpage = (adev->init_lvl->level != AMDGPU_INIT_LEVEL_MINIMAL_XGMI);
3005 	r = amdgpu_ras_recovery_init(adev, init_badpage);
3006 	if (r)
3007 		goto init_failed;
3008 
3009 	/**
3010 	 * In case of XGMI grab extra reference for reset domain for this device
3011 	 */
3012 	if (adev->gmc.xgmi.num_physical_nodes > 1) {
3013 		if (amdgpu_xgmi_add_device(adev) == 0) {
3014 			if (!amdgpu_sriov_vf(adev)) {
3015 				struct amdgpu_hive_info *hive = amdgpu_get_xgmi_hive(adev);
3016 
3017 				if (WARN_ON(!hive)) {
3018 					r = -ENOENT;
3019 					goto init_failed;
3020 				}
3021 
3022 				if (!hive->reset_domain ||
3023 				    !amdgpu_reset_get_reset_domain(hive->reset_domain)) {
3024 					r = -ENOENT;
3025 					amdgpu_put_xgmi_hive(hive);
3026 					goto init_failed;
3027 				}
3028 
3029 				/* Drop the early temporary reset domain we created for device */
3030 				amdgpu_reset_put_reset_domain(adev->reset_domain);
3031 				adev->reset_domain = hive->reset_domain;
3032 				amdgpu_put_xgmi_hive(hive);
3033 			}
3034 		}
3035 	}
3036 
3037 	r = amdgpu_device_init_schedulers(adev);
3038 	if (r)
3039 		goto init_failed;
3040 
3041 	if (adev->mman.buffer_funcs_ring->sched.ready)
3042 		amdgpu_ttm_set_buffer_funcs_status(adev, true);
3043 
3044 	/* Don't init kfd if whole hive need to be reset during init */
3045 	if (adev->init_lvl->level != AMDGPU_INIT_LEVEL_MINIMAL_XGMI) {
3046 		kgd2kfd_init_zone_device(adev);
3047 		amdgpu_amdkfd_device_init(adev);
3048 	}
3049 
3050 	amdgpu_fru_get_product_info(adev);
3051 
3052 init_failed:
3053 
3054 	return r;
3055 }
3056 
3057 /**
3058  * amdgpu_device_fill_reset_magic - writes reset magic to gart pointer
3059  *
3060  * @adev: amdgpu_device pointer
3061  *
3062  * Writes a reset magic value to the gart pointer in VRAM.  The driver calls
3063  * this function before a GPU reset.  If the value is retained after a
3064  * GPU reset, VRAM has not been lost.  Some GPU resets may destry VRAM contents.
3065  */
3066 static void amdgpu_device_fill_reset_magic(struct amdgpu_device *adev)
3067 {
3068 	memcpy(adev->reset_magic, adev->gart.ptr, AMDGPU_RESET_MAGIC_NUM);
3069 }
3070 
3071 /**
3072  * amdgpu_device_check_vram_lost - check if vram is valid
3073  *
3074  * @adev: amdgpu_device pointer
3075  *
3076  * Checks the reset magic value written to the gart pointer in VRAM.
3077  * The driver calls this after a GPU reset to see if the contents of
3078  * VRAM is lost or now.
3079  * returns true if vram is lost, false if not.
3080  */
3081 static bool amdgpu_device_check_vram_lost(struct amdgpu_device *adev)
3082 {
3083 	if (memcmp(adev->gart.ptr, adev->reset_magic,
3084 			AMDGPU_RESET_MAGIC_NUM))
3085 		return true;
3086 
3087 	if (!amdgpu_in_reset(adev))
3088 		return false;
3089 
3090 	/*
3091 	 * For all ASICs with baco/mode1 reset, the VRAM is
3092 	 * always assumed to be lost.
3093 	 */
3094 	switch (amdgpu_asic_reset_method(adev)) {
3095 	case AMD_RESET_METHOD_BACO:
3096 	case AMD_RESET_METHOD_MODE1:
3097 		return true;
3098 	default:
3099 		return false;
3100 	}
3101 }
3102 
3103 /**
3104  * amdgpu_device_set_cg_state - set clockgating for amdgpu device
3105  *
3106  * @adev: amdgpu_device pointer
3107  * @state: clockgating state (gate or ungate)
3108  *
3109  * The list of all the hardware IPs that make up the asic is walked and the
3110  * set_clockgating_state callbacks are run.
3111  * Late initialization pass enabling clockgating for hardware IPs.
3112  * Fini or suspend, pass disabling clockgating for hardware IPs.
3113  * Returns 0 on success, negative error code on failure.
3114  */
3115 
3116 int amdgpu_device_set_cg_state(struct amdgpu_device *adev,
3117 			       enum amd_clockgating_state state)
3118 {
3119 	int i, j, r;
3120 
3121 	if (amdgpu_emu_mode == 1)
3122 		return 0;
3123 
3124 	for (j = 0; j < adev->num_ip_blocks; j++) {
3125 		i = state == AMD_CG_STATE_GATE ? j : adev->num_ip_blocks - j - 1;
3126 		if (!adev->ip_blocks[i].status.late_initialized)
3127 			continue;
3128 		/* skip CG for GFX, SDMA on S0ix */
3129 		if (adev->in_s0ix &&
3130 		    (adev->ip_blocks[i].version->type == AMD_IP_BLOCK_TYPE_GFX ||
3131 		     adev->ip_blocks[i].version->type == AMD_IP_BLOCK_TYPE_SDMA))
3132 			continue;
3133 		/* skip CG for VCE/UVD, it's handled specially */
3134 		if (adev->ip_blocks[i].version->type != AMD_IP_BLOCK_TYPE_UVD &&
3135 		    adev->ip_blocks[i].version->type != AMD_IP_BLOCK_TYPE_VCE &&
3136 		    adev->ip_blocks[i].version->type != AMD_IP_BLOCK_TYPE_VCN &&
3137 		    adev->ip_blocks[i].version->type != AMD_IP_BLOCK_TYPE_JPEG &&
3138 		    adev->ip_blocks[i].version->funcs->set_clockgating_state) {
3139 			/* enable clockgating to save power */
3140 			r = adev->ip_blocks[i].version->funcs->set_clockgating_state((void *)adev,
3141 										     state);
3142 			if (r) {
3143 				DRM_ERROR("set_clockgating_state(gate) of IP block <%s> failed %d\n",
3144 					  adev->ip_blocks[i].version->funcs->name, r);
3145 				return r;
3146 			}
3147 		}
3148 	}
3149 
3150 	return 0;
3151 }
3152 
3153 int amdgpu_device_set_pg_state(struct amdgpu_device *adev,
3154 			       enum amd_powergating_state state)
3155 {
3156 	int i, j, r;
3157 
3158 	if (amdgpu_emu_mode == 1)
3159 		return 0;
3160 
3161 	for (j = 0; j < adev->num_ip_blocks; j++) {
3162 		i = state == AMD_PG_STATE_GATE ? j : adev->num_ip_blocks - j - 1;
3163 		if (!adev->ip_blocks[i].status.late_initialized)
3164 			continue;
3165 		/* skip PG for GFX, SDMA on S0ix */
3166 		if (adev->in_s0ix &&
3167 		    (adev->ip_blocks[i].version->type == AMD_IP_BLOCK_TYPE_GFX ||
3168 		     adev->ip_blocks[i].version->type == AMD_IP_BLOCK_TYPE_SDMA))
3169 			continue;
3170 		/* skip CG for VCE/UVD, it's handled specially */
3171 		if (adev->ip_blocks[i].version->type != AMD_IP_BLOCK_TYPE_UVD &&
3172 		    adev->ip_blocks[i].version->type != AMD_IP_BLOCK_TYPE_VCE &&
3173 		    adev->ip_blocks[i].version->type != AMD_IP_BLOCK_TYPE_VCN &&
3174 		    adev->ip_blocks[i].version->type != AMD_IP_BLOCK_TYPE_JPEG &&
3175 		    adev->ip_blocks[i].version->funcs->set_powergating_state) {
3176 			/* enable powergating to save power */
3177 			r = adev->ip_blocks[i].version->funcs->set_powergating_state((void *)adev,
3178 											state);
3179 			if (r) {
3180 				DRM_ERROR("set_powergating_state(gate) of IP block <%s> failed %d\n",
3181 					  adev->ip_blocks[i].version->funcs->name, r);
3182 				return r;
3183 			}
3184 		}
3185 	}
3186 	return 0;
3187 }
3188 
3189 static int amdgpu_device_enable_mgpu_fan_boost(void)
3190 {
3191 	struct amdgpu_gpu_instance *gpu_ins;
3192 	struct amdgpu_device *adev;
3193 	int i, ret = 0;
3194 
3195 	mutex_lock(&mgpu_info.mutex);
3196 
3197 	/*
3198 	 * MGPU fan boost feature should be enabled
3199 	 * only when there are two or more dGPUs in
3200 	 * the system
3201 	 */
3202 	if (mgpu_info.num_dgpu < 2)
3203 		goto out;
3204 
3205 	for (i = 0; i < mgpu_info.num_dgpu; i++) {
3206 		gpu_ins = &(mgpu_info.gpu_ins[i]);
3207 		adev = gpu_ins->adev;
3208 		if (!(adev->flags & AMD_IS_APU) &&
3209 		    !gpu_ins->mgpu_fan_enabled) {
3210 			ret = amdgpu_dpm_enable_mgpu_fan_boost(adev);
3211 			if (ret)
3212 				break;
3213 
3214 			gpu_ins->mgpu_fan_enabled = 1;
3215 		}
3216 	}
3217 
3218 out:
3219 	mutex_unlock(&mgpu_info.mutex);
3220 
3221 	return ret;
3222 }
3223 
3224 /**
3225  * amdgpu_device_ip_late_init - run late init for hardware IPs
3226  *
3227  * @adev: amdgpu_device pointer
3228  *
3229  * Late initialization pass for hardware IPs.  The list of all the hardware
3230  * IPs that make up the asic is walked and the late_init callbacks are run.
3231  * late_init covers any special initialization that an IP requires
3232  * after all of the have been initialized or something that needs to happen
3233  * late in the init process.
3234  * Returns 0 on success, negative error code on failure.
3235  */
3236 static int amdgpu_device_ip_late_init(struct amdgpu_device *adev)
3237 {
3238 	struct amdgpu_gpu_instance *gpu_instance;
3239 	int i = 0, r;
3240 
3241 	for (i = 0; i < adev->num_ip_blocks; i++) {
3242 		if (!adev->ip_blocks[i].status.hw)
3243 			continue;
3244 		if (adev->ip_blocks[i].version->funcs->late_init) {
3245 			r = adev->ip_blocks[i].version->funcs->late_init(&adev->ip_blocks[i]);
3246 			if (r) {
3247 				DRM_ERROR("late_init of IP block <%s> failed %d\n",
3248 					  adev->ip_blocks[i].version->funcs->name, r);
3249 				return r;
3250 			}
3251 		}
3252 		adev->ip_blocks[i].status.late_initialized = true;
3253 	}
3254 
3255 	r = amdgpu_ras_late_init(adev);
3256 	if (r) {
3257 		DRM_ERROR("amdgpu_ras_late_init failed %d", r);
3258 		return r;
3259 	}
3260 
3261 	if (!amdgpu_reset_in_recovery(adev))
3262 		amdgpu_ras_set_error_query_ready(adev, true);
3263 
3264 	amdgpu_device_set_cg_state(adev, AMD_CG_STATE_GATE);
3265 	amdgpu_device_set_pg_state(adev, AMD_PG_STATE_GATE);
3266 
3267 	amdgpu_device_fill_reset_magic(adev);
3268 
3269 	r = amdgpu_device_enable_mgpu_fan_boost();
3270 	if (r)
3271 		DRM_ERROR("enable mgpu fan boost failed (%d).\n", r);
3272 
3273 	/* For passthrough configuration on arcturus and aldebaran, enable special handling SBR */
3274 	if (amdgpu_passthrough(adev) &&
3275 	    ((adev->asic_type == CHIP_ARCTURUS && adev->gmc.xgmi.num_physical_nodes > 1) ||
3276 	     adev->asic_type == CHIP_ALDEBARAN))
3277 		amdgpu_dpm_handle_passthrough_sbr(adev, true);
3278 
3279 	if (adev->gmc.xgmi.num_physical_nodes > 1) {
3280 		mutex_lock(&mgpu_info.mutex);
3281 
3282 		/*
3283 		 * Reset device p-state to low as this was booted with high.
3284 		 *
3285 		 * This should be performed only after all devices from the same
3286 		 * hive get initialized.
3287 		 *
3288 		 * However, it's unknown how many device in the hive in advance.
3289 		 * As this is counted one by one during devices initializations.
3290 		 *
3291 		 * So, we wait for all XGMI interlinked devices initialized.
3292 		 * This may bring some delays as those devices may come from
3293 		 * different hives. But that should be OK.
3294 		 */
3295 		if (mgpu_info.num_dgpu == adev->gmc.xgmi.num_physical_nodes) {
3296 			for (i = 0; i < mgpu_info.num_gpu; i++) {
3297 				gpu_instance = &(mgpu_info.gpu_ins[i]);
3298 				if (gpu_instance->adev->flags & AMD_IS_APU)
3299 					continue;
3300 
3301 				r = amdgpu_xgmi_set_pstate(gpu_instance->adev,
3302 						AMDGPU_XGMI_PSTATE_MIN);
3303 				if (r) {
3304 					DRM_ERROR("pstate setting failed (%d).\n", r);
3305 					break;
3306 				}
3307 			}
3308 		}
3309 
3310 		mutex_unlock(&mgpu_info.mutex);
3311 	}
3312 
3313 	return 0;
3314 }
3315 
3316 static void amdgpu_ip_block_hw_fini(struct amdgpu_ip_block *ip_block)
3317 {
3318 	int r;
3319 
3320 	if (!ip_block->version->funcs->hw_fini) {
3321 		DRM_ERROR("hw_fini of IP block <%s> not defined\n",
3322 			  ip_block->version->funcs->name);
3323 	} else {
3324 		r = ip_block->version->funcs->hw_fini(ip_block);
3325 		/* XXX handle errors */
3326 		if (r) {
3327 			DRM_DEBUG("hw_fini of IP block <%s> failed %d\n",
3328 				  ip_block->version->funcs->name, r);
3329 		}
3330 	}
3331 
3332 	ip_block->status.hw = false;
3333 }
3334 
3335 /**
3336  * amdgpu_device_smu_fini_early - smu hw_fini wrapper
3337  *
3338  * @adev: amdgpu_device pointer
3339  *
3340  * For ASICs need to disable SMC first
3341  */
3342 static void amdgpu_device_smu_fini_early(struct amdgpu_device *adev)
3343 {
3344 	int i;
3345 
3346 	if (amdgpu_ip_version(adev, GC_HWIP, 0) > IP_VERSION(9, 0, 0))
3347 		return;
3348 
3349 	for (i = 0; i < adev->num_ip_blocks; i++) {
3350 		if (!adev->ip_blocks[i].status.hw)
3351 			continue;
3352 		if (adev->ip_blocks[i].version->type == AMD_IP_BLOCK_TYPE_SMC) {
3353 			amdgpu_ip_block_hw_fini(&adev->ip_blocks[i]);
3354 			break;
3355 		}
3356 	}
3357 }
3358 
3359 static int amdgpu_device_ip_fini_early(struct amdgpu_device *adev)
3360 {
3361 	int i, r;
3362 
3363 	for (i = 0; i < adev->num_ip_blocks; i++) {
3364 		if (!adev->ip_blocks[i].version->funcs->early_fini)
3365 			continue;
3366 
3367 		r = adev->ip_blocks[i].version->funcs->early_fini(&adev->ip_blocks[i]);
3368 		if (r) {
3369 			DRM_DEBUG("early_fini of IP block <%s> failed %d\n",
3370 				  adev->ip_blocks[i].version->funcs->name, r);
3371 		}
3372 	}
3373 
3374 	amdgpu_device_set_pg_state(adev, AMD_PG_STATE_UNGATE);
3375 	amdgpu_device_set_cg_state(adev, AMD_CG_STATE_UNGATE);
3376 
3377 	amdgpu_amdkfd_suspend(adev, false);
3378 
3379 	/* Workaroud for ASICs need to disable SMC first */
3380 	amdgpu_device_smu_fini_early(adev);
3381 
3382 	for (i = adev->num_ip_blocks - 1; i >= 0; i--) {
3383 		if (!adev->ip_blocks[i].status.hw)
3384 			continue;
3385 
3386 		amdgpu_ip_block_hw_fini(&adev->ip_blocks[i]);
3387 	}
3388 
3389 	if (amdgpu_sriov_vf(adev)) {
3390 		if (amdgpu_virt_release_full_gpu(adev, false))
3391 			DRM_ERROR("failed to release exclusive mode on fini\n");
3392 	}
3393 
3394 	return 0;
3395 }
3396 
3397 /**
3398  * amdgpu_device_ip_fini - run fini for hardware IPs
3399  *
3400  * @adev: amdgpu_device pointer
3401  *
3402  * Main teardown pass for hardware IPs.  The list of all the hardware
3403  * IPs that make up the asic is walked and the hw_fini and sw_fini callbacks
3404  * are run.  hw_fini tears down the hardware associated with each IP
3405  * and sw_fini tears down any software state associated with each IP.
3406  * Returns 0 on success, negative error code on failure.
3407  */
3408 static int amdgpu_device_ip_fini(struct amdgpu_device *adev)
3409 {
3410 	int i, r;
3411 
3412 	if (amdgpu_sriov_vf(adev) && adev->virt.ras_init_done)
3413 		amdgpu_virt_release_ras_err_handler_data(adev);
3414 
3415 	if (adev->gmc.xgmi.num_physical_nodes > 1)
3416 		amdgpu_xgmi_remove_device(adev);
3417 
3418 	amdgpu_amdkfd_device_fini_sw(adev);
3419 
3420 	for (i = adev->num_ip_blocks - 1; i >= 0; i--) {
3421 		if (!adev->ip_blocks[i].status.sw)
3422 			continue;
3423 
3424 		if (adev->ip_blocks[i].version->type == AMD_IP_BLOCK_TYPE_GMC) {
3425 			amdgpu_ucode_free_bo(adev);
3426 			amdgpu_free_static_csa(&adev->virt.csa_obj);
3427 			amdgpu_device_wb_fini(adev);
3428 			amdgpu_device_mem_scratch_fini(adev);
3429 			amdgpu_ib_pool_fini(adev);
3430 			amdgpu_seq64_fini(adev);
3431 		}
3432 		if (adev->ip_blocks[i].version->funcs->sw_fini) {
3433 			r = adev->ip_blocks[i].version->funcs->sw_fini(&adev->ip_blocks[i]);
3434 			/* XXX handle errors */
3435 			if (r) {
3436 				DRM_DEBUG("sw_fini of IP block <%s> failed %d\n",
3437 					  adev->ip_blocks[i].version->funcs->name, r);
3438 			}
3439 		}
3440 		adev->ip_blocks[i].status.sw = false;
3441 		adev->ip_blocks[i].status.valid = false;
3442 	}
3443 
3444 	for (i = adev->num_ip_blocks - 1; i >= 0; i--) {
3445 		if (!adev->ip_blocks[i].status.late_initialized)
3446 			continue;
3447 		if (adev->ip_blocks[i].version->funcs->late_fini)
3448 			adev->ip_blocks[i].version->funcs->late_fini(&adev->ip_blocks[i]);
3449 		adev->ip_blocks[i].status.late_initialized = false;
3450 	}
3451 
3452 	amdgpu_ras_fini(adev);
3453 
3454 	return 0;
3455 }
3456 
3457 /**
3458  * amdgpu_device_delayed_init_work_handler - work handler for IB tests
3459  *
3460  * @work: work_struct.
3461  */
3462 static void amdgpu_device_delayed_init_work_handler(struct work_struct *work)
3463 {
3464 	struct amdgpu_device *adev =
3465 		container_of(work, struct amdgpu_device, delayed_init_work.work);
3466 	int r;
3467 
3468 	r = amdgpu_ib_ring_tests(adev);
3469 	if (r)
3470 		DRM_ERROR("ib ring test failed (%d).\n", r);
3471 }
3472 
3473 static void amdgpu_device_delay_enable_gfx_off(struct work_struct *work)
3474 {
3475 	struct amdgpu_device *adev =
3476 		container_of(work, struct amdgpu_device, gfx.gfx_off_delay_work.work);
3477 
3478 	WARN_ON_ONCE(adev->gfx.gfx_off_state);
3479 	WARN_ON_ONCE(adev->gfx.gfx_off_req_count);
3480 
3481 	if (!amdgpu_dpm_set_powergating_by_smu(adev, AMD_IP_BLOCK_TYPE_GFX, true))
3482 		adev->gfx.gfx_off_state = true;
3483 }
3484 
3485 /**
3486  * amdgpu_device_ip_suspend_phase1 - run suspend for hardware IPs (phase 1)
3487  *
3488  * @adev: amdgpu_device pointer
3489  *
3490  * Main suspend function for hardware IPs.  The list of all the hardware
3491  * IPs that make up the asic is walked, clockgating is disabled and the
3492  * suspend callbacks are run.  suspend puts the hardware and software state
3493  * in each IP into a state suitable for suspend.
3494  * Returns 0 on success, negative error code on failure.
3495  */
3496 static int amdgpu_device_ip_suspend_phase1(struct amdgpu_device *adev)
3497 {
3498 	int i, r;
3499 
3500 	amdgpu_device_set_pg_state(adev, AMD_PG_STATE_UNGATE);
3501 	amdgpu_device_set_cg_state(adev, AMD_CG_STATE_UNGATE);
3502 
3503 	/*
3504 	 * Per PMFW team's suggestion, driver needs to handle gfxoff
3505 	 * and df cstate features disablement for gpu reset(e.g. Mode1Reset)
3506 	 * scenario. Add the missing df cstate disablement here.
3507 	 */
3508 	if (amdgpu_dpm_set_df_cstate(adev, DF_CSTATE_DISALLOW))
3509 		dev_warn(adev->dev, "Failed to disallow df cstate");
3510 
3511 	for (i = adev->num_ip_blocks - 1; i >= 0; i--) {
3512 		if (!adev->ip_blocks[i].status.valid)
3513 			continue;
3514 
3515 		/* displays are handled separately */
3516 		if (adev->ip_blocks[i].version->type != AMD_IP_BLOCK_TYPE_DCE)
3517 			continue;
3518 
3519 		/* XXX handle errors */
3520 		r = amdgpu_ip_block_suspend(&adev->ip_blocks[i]);
3521 		if (r)
3522 			return r;
3523 	}
3524 
3525 	return 0;
3526 }
3527 
3528 /**
3529  * amdgpu_device_ip_suspend_phase2 - run suspend for hardware IPs (phase 2)
3530  *
3531  * @adev: amdgpu_device pointer
3532  *
3533  * Main suspend function for hardware IPs.  The list of all the hardware
3534  * IPs that make up the asic is walked, clockgating is disabled and the
3535  * suspend callbacks are run.  suspend puts the hardware and software state
3536  * in each IP into a state suitable for suspend.
3537  * Returns 0 on success, negative error code on failure.
3538  */
3539 static int amdgpu_device_ip_suspend_phase2(struct amdgpu_device *adev)
3540 {
3541 	int i, r;
3542 
3543 	if (adev->in_s0ix)
3544 		amdgpu_dpm_gfx_state_change(adev, sGpuChangeState_D3Entry);
3545 
3546 	for (i = adev->num_ip_blocks - 1; i >= 0; i--) {
3547 		if (!adev->ip_blocks[i].status.valid)
3548 			continue;
3549 		/* displays are handled in phase1 */
3550 		if (adev->ip_blocks[i].version->type == AMD_IP_BLOCK_TYPE_DCE)
3551 			continue;
3552 		/* PSP lost connection when err_event_athub occurs */
3553 		if (amdgpu_ras_intr_triggered() &&
3554 		    adev->ip_blocks[i].version->type == AMD_IP_BLOCK_TYPE_PSP) {
3555 			adev->ip_blocks[i].status.hw = false;
3556 			continue;
3557 		}
3558 
3559 		/* skip unnecessary suspend if we do not initialize them yet */
3560 		if (!amdgpu_ip_member_of_hwini(
3561 			    adev, adev->ip_blocks[i].version->type))
3562 			continue;
3563 
3564 		/* skip suspend of gfx/mes and psp for S0ix
3565 		 * gfx is in gfxoff state, so on resume it will exit gfxoff just
3566 		 * like at runtime. PSP is also part of the always on hardware
3567 		 * so no need to suspend it.
3568 		 */
3569 		if (adev->in_s0ix &&
3570 		    (adev->ip_blocks[i].version->type == AMD_IP_BLOCK_TYPE_PSP ||
3571 		     adev->ip_blocks[i].version->type == AMD_IP_BLOCK_TYPE_GFX ||
3572 		     adev->ip_blocks[i].version->type == AMD_IP_BLOCK_TYPE_MES))
3573 			continue;
3574 
3575 		/* SDMA 5.x+ is part of GFX power domain so it's covered by GFXOFF */
3576 		if (adev->in_s0ix &&
3577 		    (amdgpu_ip_version(adev, SDMA0_HWIP, 0) >=
3578 		     IP_VERSION(5, 0, 0)) &&
3579 		    (adev->ip_blocks[i].version->type ==
3580 		     AMD_IP_BLOCK_TYPE_SDMA))
3581 			continue;
3582 
3583 		/* Once swPSP provides the IMU, RLC FW binaries to TOS during cold-boot.
3584 		 * These are in TMR, hence are expected to be reused by PSP-TOS to reload
3585 		 * from this location and RLC Autoload automatically also gets loaded
3586 		 * from here based on PMFW -> PSP message during re-init sequence.
3587 		 * Therefore, the psp suspend & resume should be skipped to avoid destroy
3588 		 * the TMR and reload FWs again for IMU enabled APU ASICs.
3589 		 */
3590 		if (amdgpu_in_reset(adev) &&
3591 		    (adev->flags & AMD_IS_APU) && adev->gfx.imu.funcs &&
3592 		    adev->ip_blocks[i].version->type == AMD_IP_BLOCK_TYPE_PSP)
3593 			continue;
3594 
3595 		/* XXX handle errors */
3596 		r = amdgpu_ip_block_suspend(&adev->ip_blocks[i]);
3597 		adev->ip_blocks[i].status.hw = false;
3598 
3599 		/* handle putting the SMC in the appropriate state */
3600 		if (!amdgpu_sriov_vf(adev)) {
3601 			if (adev->ip_blocks[i].version->type == AMD_IP_BLOCK_TYPE_SMC) {
3602 				r = amdgpu_dpm_set_mp1_state(adev, adev->mp1_state);
3603 				if (r) {
3604 					DRM_ERROR("SMC failed to set mp1 state %d, %d\n",
3605 							adev->mp1_state, r);
3606 					return r;
3607 				}
3608 			}
3609 		}
3610 	}
3611 
3612 	return 0;
3613 }
3614 
3615 /**
3616  * amdgpu_device_ip_suspend - run suspend for hardware IPs
3617  *
3618  * @adev: amdgpu_device pointer
3619  *
3620  * Main suspend function for hardware IPs.  The list of all the hardware
3621  * IPs that make up the asic is walked, clockgating is disabled and the
3622  * suspend callbacks are run.  suspend puts the hardware and software state
3623  * in each IP into a state suitable for suspend.
3624  * Returns 0 on success, negative error code on failure.
3625  */
3626 int amdgpu_device_ip_suspend(struct amdgpu_device *adev)
3627 {
3628 	int r;
3629 
3630 	if (amdgpu_sriov_vf(adev)) {
3631 		amdgpu_virt_fini_data_exchange(adev);
3632 		amdgpu_virt_request_full_gpu(adev, false);
3633 	}
3634 
3635 	amdgpu_ttm_set_buffer_funcs_status(adev, false);
3636 
3637 	r = amdgpu_device_ip_suspend_phase1(adev);
3638 	if (r)
3639 		return r;
3640 	r = amdgpu_device_ip_suspend_phase2(adev);
3641 
3642 	if (amdgpu_sriov_vf(adev))
3643 		amdgpu_virt_release_full_gpu(adev, false);
3644 
3645 	return r;
3646 }
3647 
3648 static int amdgpu_device_ip_reinit_early_sriov(struct amdgpu_device *adev)
3649 {
3650 	int i, r;
3651 
3652 	static enum amd_ip_block_type ip_order[] = {
3653 		AMD_IP_BLOCK_TYPE_COMMON,
3654 		AMD_IP_BLOCK_TYPE_GMC,
3655 		AMD_IP_BLOCK_TYPE_PSP,
3656 		AMD_IP_BLOCK_TYPE_IH,
3657 	};
3658 
3659 	for (i = 0; i < adev->num_ip_blocks; i++) {
3660 		int j;
3661 		struct amdgpu_ip_block *block;
3662 
3663 		block = &adev->ip_blocks[i];
3664 		block->status.hw = false;
3665 
3666 		for (j = 0; j < ARRAY_SIZE(ip_order); j++) {
3667 
3668 			if (block->version->type != ip_order[j] ||
3669 				!block->status.valid)
3670 				continue;
3671 
3672 			r = block->version->funcs->hw_init(&adev->ip_blocks[i]);
3673 			if (r) {
3674 				dev_err(adev->dev, "RE-INIT-early: %s failed\n",
3675 					 block->version->funcs->name);
3676 				return r;
3677 			}
3678 			block->status.hw = true;
3679 		}
3680 	}
3681 
3682 	return 0;
3683 }
3684 
3685 static int amdgpu_device_ip_reinit_late_sriov(struct amdgpu_device *adev)
3686 {
3687 	struct amdgpu_ip_block *block;
3688 	int i, r = 0;
3689 
3690 	static enum amd_ip_block_type ip_order[] = {
3691 		AMD_IP_BLOCK_TYPE_SMC,
3692 		AMD_IP_BLOCK_TYPE_DCE,
3693 		AMD_IP_BLOCK_TYPE_GFX,
3694 		AMD_IP_BLOCK_TYPE_SDMA,
3695 		AMD_IP_BLOCK_TYPE_MES,
3696 		AMD_IP_BLOCK_TYPE_UVD,
3697 		AMD_IP_BLOCK_TYPE_VCE,
3698 		AMD_IP_BLOCK_TYPE_VCN,
3699 		AMD_IP_BLOCK_TYPE_JPEG
3700 	};
3701 
3702 	for (i = 0; i < ARRAY_SIZE(ip_order); i++) {
3703 		block = amdgpu_device_ip_get_ip_block(adev, ip_order[i]);
3704 
3705 		if (!block)
3706 			continue;
3707 
3708 		if (block->status.valid && !block->status.hw) {
3709 			if (block->version->type == AMD_IP_BLOCK_TYPE_SMC) {
3710 				r = amdgpu_ip_block_resume(block);
3711 			} else {
3712 				r = block->version->funcs->hw_init(block);
3713 			}
3714 
3715 			if (r) {
3716 				dev_err(adev->dev, "RE-INIT-late: %s failed\n",
3717 					 block->version->funcs->name);
3718 				break;
3719 			}
3720 			block->status.hw = true;
3721 		}
3722 	}
3723 
3724 	return r;
3725 }
3726 
3727 /**
3728  * amdgpu_device_ip_resume_phase1 - run resume for hardware IPs
3729  *
3730  * @adev: amdgpu_device pointer
3731  *
3732  * First resume function for hardware IPs.  The list of all the hardware
3733  * IPs that make up the asic is walked and the resume callbacks are run for
3734  * COMMON, GMC, and IH.  resume puts the hardware into a functional state
3735  * after a suspend and updates the software state as necessary.  This
3736  * function is also used for restoring the GPU after a GPU reset.
3737  * Returns 0 on success, negative error code on failure.
3738  */
3739 static int amdgpu_device_ip_resume_phase1(struct amdgpu_device *adev)
3740 {
3741 	int i, r;
3742 
3743 	for (i = 0; i < adev->num_ip_blocks; i++) {
3744 		if (!adev->ip_blocks[i].status.valid || adev->ip_blocks[i].status.hw)
3745 			continue;
3746 		if (adev->ip_blocks[i].version->type == AMD_IP_BLOCK_TYPE_COMMON ||
3747 		    adev->ip_blocks[i].version->type == AMD_IP_BLOCK_TYPE_GMC ||
3748 		    adev->ip_blocks[i].version->type == AMD_IP_BLOCK_TYPE_IH ||
3749 		    (adev->ip_blocks[i].version->type == AMD_IP_BLOCK_TYPE_PSP && amdgpu_sriov_vf(adev))) {
3750 
3751 			r = amdgpu_ip_block_resume(&adev->ip_blocks[i]);
3752 			if (r)
3753 				return r;
3754 		}
3755 	}
3756 
3757 	return 0;
3758 }
3759 
3760 /**
3761  * amdgpu_device_ip_resume_phase2 - run resume for hardware IPs
3762  *
3763  * @adev: amdgpu_device pointer
3764  *
3765  * Second resume function for hardware IPs.  The list of all the hardware
3766  * IPs that make up the asic is walked and the resume callbacks are run for
3767  * all blocks except COMMON, GMC, and IH.  resume puts the hardware into a
3768  * functional state after a suspend and updates the software state as
3769  * necessary.  This function is also used for restoring the GPU after a GPU
3770  * reset.
3771  * Returns 0 on success, negative error code on failure.
3772  */
3773 static int amdgpu_device_ip_resume_phase2(struct amdgpu_device *adev)
3774 {
3775 	int i, r;
3776 
3777 	for (i = 0; i < adev->num_ip_blocks; i++) {
3778 		if (!adev->ip_blocks[i].status.valid || adev->ip_blocks[i].status.hw)
3779 			continue;
3780 		if (adev->ip_blocks[i].version->type == AMD_IP_BLOCK_TYPE_COMMON ||
3781 		    adev->ip_blocks[i].version->type == AMD_IP_BLOCK_TYPE_GMC ||
3782 		    adev->ip_blocks[i].version->type == AMD_IP_BLOCK_TYPE_IH ||
3783 		    adev->ip_blocks[i].version->type == AMD_IP_BLOCK_TYPE_DCE ||
3784 		    adev->ip_blocks[i].version->type == AMD_IP_BLOCK_TYPE_PSP)
3785 			continue;
3786 		r = amdgpu_ip_block_resume(&adev->ip_blocks[i]);
3787 		if (r)
3788 			return r;
3789 	}
3790 
3791 	return 0;
3792 }
3793 
3794 /**
3795  * amdgpu_device_ip_resume_phase3 - run resume for hardware IPs
3796  *
3797  * @adev: amdgpu_device pointer
3798  *
3799  * Third resume function for hardware IPs.  The list of all the hardware
3800  * IPs that make up the asic is walked and the resume callbacks are run for
3801  * all DCE.  resume puts the hardware into a functional state after a suspend
3802  * and updates the software state as necessary.  This function is also used
3803  * for restoring the GPU after a GPU reset.
3804  *
3805  * Returns 0 on success, negative error code on failure.
3806  */
3807 static int amdgpu_device_ip_resume_phase3(struct amdgpu_device *adev)
3808 {
3809 	int i, r;
3810 
3811 	for (i = 0; i < adev->num_ip_blocks; i++) {
3812 		if (!adev->ip_blocks[i].status.valid || adev->ip_blocks[i].status.hw)
3813 			continue;
3814 		if (adev->ip_blocks[i].version->type == AMD_IP_BLOCK_TYPE_DCE) {
3815 			r = amdgpu_ip_block_resume(&adev->ip_blocks[i]);
3816 			if (r)
3817 				return r;
3818 		}
3819 	}
3820 
3821 	return 0;
3822 }
3823 
3824 /**
3825  * amdgpu_device_ip_resume - run resume for hardware IPs
3826  *
3827  * @adev: amdgpu_device pointer
3828  *
3829  * Main resume function for hardware IPs.  The hardware IPs
3830  * are split into two resume functions because they are
3831  * also used in recovering from a GPU reset and some additional
3832  * steps need to be take between them.  In this case (S3/S4) they are
3833  * run sequentially.
3834  * Returns 0 on success, negative error code on failure.
3835  */
3836 static int amdgpu_device_ip_resume(struct amdgpu_device *adev)
3837 {
3838 	int r;
3839 
3840 	r = amdgpu_device_ip_resume_phase1(adev);
3841 	if (r)
3842 		return r;
3843 
3844 	r = amdgpu_device_fw_loading(adev);
3845 	if (r)
3846 		return r;
3847 
3848 	r = amdgpu_device_ip_resume_phase2(adev);
3849 
3850 	if (adev->mman.buffer_funcs_ring->sched.ready)
3851 		amdgpu_ttm_set_buffer_funcs_status(adev, true);
3852 
3853 	if (r)
3854 		return r;
3855 
3856 	amdgpu_fence_driver_hw_init(adev);
3857 
3858 	r = amdgpu_device_ip_resume_phase3(adev);
3859 
3860 	return r;
3861 }
3862 
3863 /**
3864  * amdgpu_device_detect_sriov_bios - determine if the board supports SR-IOV
3865  *
3866  * @adev: amdgpu_device pointer
3867  *
3868  * Query the VBIOS data tables to determine if the board supports SR-IOV.
3869  */
3870 static void amdgpu_device_detect_sriov_bios(struct amdgpu_device *adev)
3871 {
3872 	if (amdgpu_sriov_vf(adev)) {
3873 		if (adev->is_atom_fw) {
3874 			if (amdgpu_atomfirmware_gpu_virtualization_supported(adev))
3875 				adev->virt.caps |= AMDGPU_SRIOV_CAPS_SRIOV_VBIOS;
3876 		} else {
3877 			if (amdgpu_atombios_has_gpu_virtualization_table(adev))
3878 				adev->virt.caps |= AMDGPU_SRIOV_CAPS_SRIOV_VBIOS;
3879 		}
3880 
3881 		if (!(adev->virt.caps & AMDGPU_SRIOV_CAPS_SRIOV_VBIOS))
3882 			amdgpu_vf_error_put(adev, AMDGIM_ERROR_VF_NO_VBIOS, 0, 0);
3883 	}
3884 }
3885 
3886 /**
3887  * amdgpu_device_asic_has_dc_support - determine if DC supports the asic
3888  *
3889  * @asic_type: AMD asic type
3890  *
3891  * Check if there is DC (new modesetting infrastructre) support for an asic.
3892  * returns true if DC has support, false if not.
3893  */
3894 bool amdgpu_device_asic_has_dc_support(enum amd_asic_type asic_type)
3895 {
3896 	switch (asic_type) {
3897 #ifdef CONFIG_DRM_AMDGPU_SI
3898 	case CHIP_HAINAN:
3899 #endif
3900 	case CHIP_TOPAZ:
3901 		/* chips with no display hardware */
3902 		return false;
3903 #if defined(CONFIG_DRM_AMD_DC)
3904 	case CHIP_TAHITI:
3905 	case CHIP_PITCAIRN:
3906 	case CHIP_VERDE:
3907 	case CHIP_OLAND:
3908 		/*
3909 		 * We have systems in the wild with these ASICs that require
3910 		 * LVDS and VGA support which is not supported with DC.
3911 		 *
3912 		 * Fallback to the non-DC driver here by default so as not to
3913 		 * cause regressions.
3914 		 */
3915 #if defined(CONFIG_DRM_AMD_DC_SI)
3916 		return amdgpu_dc > 0;
3917 #else
3918 		return false;
3919 #endif
3920 	case CHIP_BONAIRE:
3921 	case CHIP_KAVERI:
3922 	case CHIP_KABINI:
3923 	case CHIP_MULLINS:
3924 		/*
3925 		 * We have systems in the wild with these ASICs that require
3926 		 * VGA support which is not supported with DC.
3927 		 *
3928 		 * Fallback to the non-DC driver here by default so as not to
3929 		 * cause regressions.
3930 		 */
3931 		return amdgpu_dc > 0;
3932 	default:
3933 		return amdgpu_dc != 0;
3934 #else
3935 	default:
3936 		if (amdgpu_dc > 0)
3937 			DRM_INFO_ONCE("Display Core has been requested via kernel parameter but isn't supported by ASIC, ignoring\n");
3938 		return false;
3939 #endif
3940 	}
3941 }
3942 
3943 /**
3944  * amdgpu_device_has_dc_support - check if dc is supported
3945  *
3946  * @adev: amdgpu_device pointer
3947  *
3948  * Returns true for supported, false for not supported
3949  */
3950 bool amdgpu_device_has_dc_support(struct amdgpu_device *adev)
3951 {
3952 	if (adev->enable_virtual_display ||
3953 	    (adev->harvest_ip_mask & AMD_HARVEST_IP_DMU_MASK))
3954 		return false;
3955 
3956 	return amdgpu_device_asic_has_dc_support(adev->asic_type);
3957 }
3958 
3959 static void amdgpu_device_xgmi_reset_func(struct work_struct *__work)
3960 {
3961 	struct amdgpu_device *adev =
3962 		container_of(__work, struct amdgpu_device, xgmi_reset_work);
3963 	struct amdgpu_hive_info *hive = amdgpu_get_xgmi_hive(adev);
3964 
3965 	/* It's a bug to not have a hive within this function */
3966 	if (WARN_ON(!hive))
3967 		return;
3968 
3969 	/*
3970 	 * Use task barrier to synchronize all xgmi reset works across the
3971 	 * hive. task_barrier_enter and task_barrier_exit will block
3972 	 * until all the threads running the xgmi reset works reach
3973 	 * those points. task_barrier_full will do both blocks.
3974 	 */
3975 	if (amdgpu_asic_reset_method(adev) == AMD_RESET_METHOD_BACO) {
3976 
3977 		task_barrier_enter(&hive->tb);
3978 		adev->asic_reset_res = amdgpu_device_baco_enter(adev_to_drm(adev));
3979 
3980 		if (adev->asic_reset_res)
3981 			goto fail;
3982 
3983 		task_barrier_exit(&hive->tb);
3984 		adev->asic_reset_res = amdgpu_device_baco_exit(adev_to_drm(adev));
3985 
3986 		if (adev->asic_reset_res)
3987 			goto fail;
3988 
3989 		amdgpu_ras_reset_error_count(adev, AMDGPU_RAS_BLOCK__MMHUB);
3990 	} else {
3991 
3992 		task_barrier_full(&hive->tb);
3993 		adev->asic_reset_res =  amdgpu_asic_reset(adev);
3994 	}
3995 
3996 fail:
3997 	if (adev->asic_reset_res)
3998 		DRM_WARN("ASIC reset failed with error, %d for drm dev, %s",
3999 			 adev->asic_reset_res, adev_to_drm(adev)->unique);
4000 	amdgpu_put_xgmi_hive(hive);
4001 }
4002 
4003 static int amdgpu_device_get_job_timeout_settings(struct amdgpu_device *adev)
4004 {
4005 	char *input = amdgpu_lockup_timeout;
4006 	char *timeout_setting = NULL;
4007 	int index = 0;
4008 	long timeout;
4009 	int ret = 0;
4010 
4011 	/*
4012 	 * By default timeout for non compute jobs is 10000
4013 	 * and 60000 for compute jobs.
4014 	 * In SR-IOV or passthrough mode, timeout for compute
4015 	 * jobs are 60000 by default.
4016 	 */
4017 	adev->gfx_timeout = msecs_to_jiffies(10000);
4018 	adev->sdma_timeout = adev->video_timeout = adev->gfx_timeout;
4019 	if (amdgpu_sriov_vf(adev))
4020 		adev->compute_timeout = amdgpu_sriov_is_pp_one_vf(adev) ?
4021 					msecs_to_jiffies(60000) : msecs_to_jiffies(10000);
4022 	else
4023 		adev->compute_timeout =  msecs_to_jiffies(60000);
4024 
4025 	if (strnlen(input, AMDGPU_MAX_TIMEOUT_PARAM_LENGTH)) {
4026 		while ((timeout_setting = strsep(&input, ",")) &&
4027 				strnlen(timeout_setting, AMDGPU_MAX_TIMEOUT_PARAM_LENGTH)) {
4028 			ret = kstrtol(timeout_setting, 0, &timeout);
4029 			if (ret)
4030 				return ret;
4031 
4032 			if (timeout == 0) {
4033 				index++;
4034 				continue;
4035 			} else if (timeout < 0) {
4036 				timeout = MAX_SCHEDULE_TIMEOUT;
4037 				dev_warn(adev->dev, "lockup timeout disabled");
4038 				add_taint(TAINT_SOFTLOCKUP, LOCKDEP_STILL_OK);
4039 			} else {
4040 				timeout = msecs_to_jiffies(timeout);
4041 			}
4042 
4043 			switch (index++) {
4044 			case 0:
4045 				adev->gfx_timeout = timeout;
4046 				break;
4047 			case 1:
4048 				adev->compute_timeout = timeout;
4049 				break;
4050 			case 2:
4051 				adev->sdma_timeout = timeout;
4052 				break;
4053 			case 3:
4054 				adev->video_timeout = timeout;
4055 				break;
4056 			default:
4057 				break;
4058 			}
4059 		}
4060 		/*
4061 		 * There is only one value specified and
4062 		 * it should apply to all non-compute jobs.
4063 		 */
4064 		if (index == 1) {
4065 			adev->sdma_timeout = adev->video_timeout = adev->gfx_timeout;
4066 			if (amdgpu_sriov_vf(adev) || amdgpu_passthrough(adev))
4067 				adev->compute_timeout = adev->gfx_timeout;
4068 		}
4069 	}
4070 
4071 	return ret;
4072 }
4073 
4074 /**
4075  * amdgpu_device_check_iommu_direct_map - check if RAM direct mapped to GPU
4076  *
4077  * @adev: amdgpu_device pointer
4078  *
4079  * RAM direct mapped to GPU if IOMMU is not enabled or is pass through mode
4080  */
4081 static void amdgpu_device_check_iommu_direct_map(struct amdgpu_device *adev)
4082 {
4083 	struct iommu_domain *domain;
4084 
4085 	domain = iommu_get_domain_for_dev(adev->dev);
4086 	if (!domain || domain->type == IOMMU_DOMAIN_IDENTITY)
4087 		adev->ram_is_direct_mapped = true;
4088 }
4089 
4090 #if defined(CONFIG_HSA_AMD_P2P)
4091 /**
4092  * amdgpu_device_check_iommu_remap - Check if DMA remapping is enabled.
4093  *
4094  * @adev: amdgpu_device pointer
4095  *
4096  * return if IOMMU remapping bar address
4097  */
4098 static bool amdgpu_device_check_iommu_remap(struct amdgpu_device *adev)
4099 {
4100 	struct iommu_domain *domain;
4101 
4102 	domain = iommu_get_domain_for_dev(adev->dev);
4103 	if (domain && (domain->type == IOMMU_DOMAIN_DMA ||
4104 		domain->type ==	IOMMU_DOMAIN_DMA_FQ))
4105 		return true;
4106 
4107 	return false;
4108 }
4109 #endif
4110 
4111 static const struct attribute *amdgpu_dev_attributes[] = {
4112 	&dev_attr_pcie_replay_count.attr,
4113 	NULL
4114 };
4115 
4116 static void amdgpu_device_set_mcbp(struct amdgpu_device *adev)
4117 {
4118 	if (amdgpu_mcbp == 1)
4119 		adev->gfx.mcbp = true;
4120 	else if (amdgpu_mcbp == 0)
4121 		adev->gfx.mcbp = false;
4122 
4123 	if (amdgpu_sriov_vf(adev))
4124 		adev->gfx.mcbp = true;
4125 
4126 	if (adev->gfx.mcbp)
4127 		DRM_INFO("MCBP is enabled\n");
4128 }
4129 
4130 /**
4131  * amdgpu_device_init - initialize the driver
4132  *
4133  * @adev: amdgpu_device pointer
4134  * @flags: driver flags
4135  *
4136  * Initializes the driver info and hw (all asics).
4137  * Returns 0 for success or an error on failure.
4138  * Called at driver startup.
4139  */
4140 int amdgpu_device_init(struct amdgpu_device *adev,
4141 		       uint32_t flags)
4142 {
4143 	struct drm_device *ddev = adev_to_drm(adev);
4144 	struct pci_dev *pdev = adev->pdev;
4145 	int r, i;
4146 	bool px = false;
4147 	u32 max_MBps;
4148 	int tmp;
4149 
4150 	adev->shutdown = false;
4151 	adev->flags = flags;
4152 
4153 	if (amdgpu_force_asic_type >= 0 && amdgpu_force_asic_type < CHIP_LAST)
4154 		adev->asic_type = amdgpu_force_asic_type;
4155 	else
4156 		adev->asic_type = flags & AMD_ASIC_MASK;
4157 
4158 	adev->usec_timeout = AMDGPU_MAX_USEC_TIMEOUT;
4159 	if (amdgpu_emu_mode == 1)
4160 		adev->usec_timeout *= 10;
4161 	adev->gmc.gart_size = 512 * 1024 * 1024;
4162 	adev->accel_working = false;
4163 	adev->num_rings = 0;
4164 	RCU_INIT_POINTER(adev->gang_submit, dma_fence_get_stub());
4165 	adev->mman.buffer_funcs = NULL;
4166 	adev->mman.buffer_funcs_ring = NULL;
4167 	adev->vm_manager.vm_pte_funcs = NULL;
4168 	adev->vm_manager.vm_pte_num_scheds = 0;
4169 	adev->gmc.gmc_funcs = NULL;
4170 	adev->harvest_ip_mask = 0x0;
4171 	adev->fence_context = dma_fence_context_alloc(AMDGPU_MAX_RINGS);
4172 	bitmap_zero(adev->gfx.pipe_reserve_bitmap, AMDGPU_MAX_COMPUTE_QUEUES);
4173 
4174 	adev->smc_rreg = &amdgpu_invalid_rreg;
4175 	adev->smc_wreg = &amdgpu_invalid_wreg;
4176 	adev->pcie_rreg = &amdgpu_invalid_rreg;
4177 	adev->pcie_wreg = &amdgpu_invalid_wreg;
4178 	adev->pcie_rreg_ext = &amdgpu_invalid_rreg_ext;
4179 	adev->pcie_wreg_ext = &amdgpu_invalid_wreg_ext;
4180 	adev->pciep_rreg = &amdgpu_invalid_rreg;
4181 	adev->pciep_wreg = &amdgpu_invalid_wreg;
4182 	adev->pcie_rreg64 = &amdgpu_invalid_rreg64;
4183 	adev->pcie_wreg64 = &amdgpu_invalid_wreg64;
4184 	adev->pcie_rreg64_ext = &amdgpu_invalid_rreg64_ext;
4185 	adev->pcie_wreg64_ext = &amdgpu_invalid_wreg64_ext;
4186 	adev->uvd_ctx_rreg = &amdgpu_invalid_rreg;
4187 	adev->uvd_ctx_wreg = &amdgpu_invalid_wreg;
4188 	adev->didt_rreg = &amdgpu_invalid_rreg;
4189 	adev->didt_wreg = &amdgpu_invalid_wreg;
4190 	adev->gc_cac_rreg = &amdgpu_invalid_rreg;
4191 	adev->gc_cac_wreg = &amdgpu_invalid_wreg;
4192 	adev->audio_endpt_rreg = &amdgpu_block_invalid_rreg;
4193 	adev->audio_endpt_wreg = &amdgpu_block_invalid_wreg;
4194 
4195 	DRM_INFO("initializing kernel modesetting (%s 0x%04X:0x%04X 0x%04X:0x%04X 0x%02X).\n",
4196 		 amdgpu_asic_name[adev->asic_type], pdev->vendor, pdev->device,
4197 		 pdev->subsystem_vendor, pdev->subsystem_device, pdev->revision);
4198 
4199 	/* mutex initialization are all done here so we
4200 	 * can recall function without having locking issues
4201 	 */
4202 	mutex_init(&adev->firmware.mutex);
4203 	mutex_init(&adev->pm.mutex);
4204 	mutex_init(&adev->gfx.gpu_clock_mutex);
4205 	mutex_init(&adev->srbm_mutex);
4206 	mutex_init(&adev->gfx.pipe_reserve_mutex);
4207 	mutex_init(&adev->gfx.gfx_off_mutex);
4208 	mutex_init(&adev->gfx.partition_mutex);
4209 	mutex_init(&adev->grbm_idx_mutex);
4210 	mutex_init(&adev->mn_lock);
4211 	mutex_init(&adev->virt.vf_errors.lock);
4212 	mutex_init(&adev->virt.rlcg_reg_lock);
4213 	hash_init(adev->mn_hash);
4214 	mutex_init(&adev->psp.mutex);
4215 	mutex_init(&adev->notifier_lock);
4216 	mutex_init(&adev->pm.stable_pstate_ctx_lock);
4217 	mutex_init(&adev->benchmark_mutex);
4218 	mutex_init(&adev->gfx.reset_sem_mutex);
4219 	/* Initialize the mutex for cleaner shader isolation between GFX and compute processes */
4220 	mutex_init(&adev->enforce_isolation_mutex);
4221 	mutex_init(&adev->gfx.kfd_sch_mutex);
4222 
4223 	amdgpu_device_init_apu_flags(adev);
4224 
4225 	r = amdgpu_device_check_arguments(adev);
4226 	if (r)
4227 		return r;
4228 
4229 	spin_lock_init(&adev->mmio_idx_lock);
4230 	spin_lock_init(&adev->smc_idx_lock);
4231 	spin_lock_init(&adev->pcie_idx_lock);
4232 	spin_lock_init(&adev->uvd_ctx_idx_lock);
4233 	spin_lock_init(&adev->didt_idx_lock);
4234 	spin_lock_init(&adev->gc_cac_idx_lock);
4235 	spin_lock_init(&adev->se_cac_idx_lock);
4236 	spin_lock_init(&adev->audio_endpt_idx_lock);
4237 	spin_lock_init(&adev->mm_stats.lock);
4238 	spin_lock_init(&adev->wb.lock);
4239 
4240 	INIT_LIST_HEAD(&adev->reset_list);
4241 
4242 	INIT_LIST_HEAD(&adev->ras_list);
4243 
4244 	INIT_LIST_HEAD(&adev->pm.od_kobj_list);
4245 
4246 	INIT_DELAYED_WORK(&adev->delayed_init_work,
4247 			  amdgpu_device_delayed_init_work_handler);
4248 	INIT_DELAYED_WORK(&adev->gfx.gfx_off_delay_work,
4249 			  amdgpu_device_delay_enable_gfx_off);
4250 	/*
4251 	 * Initialize the enforce_isolation work structures for each XCP
4252 	 * partition.  This work handler is responsible for enforcing shader
4253 	 * isolation on AMD GPUs.  It counts the number of emitted fences for
4254 	 * each GFX and compute ring.  If there are any fences, it schedules
4255 	 * the `enforce_isolation_work` to be run after a delay.  If there are
4256 	 * no fences, it signals the Kernel Fusion Driver (KFD) to resume the
4257 	 * runqueue.
4258 	 */
4259 	for (i = 0; i < MAX_XCP; i++) {
4260 		INIT_DELAYED_WORK(&adev->gfx.enforce_isolation[i].work,
4261 				  amdgpu_gfx_enforce_isolation_handler);
4262 		adev->gfx.enforce_isolation[i].adev = adev;
4263 		adev->gfx.enforce_isolation[i].xcp_id = i;
4264 	}
4265 
4266 	INIT_WORK(&adev->xgmi_reset_work, amdgpu_device_xgmi_reset_func);
4267 
4268 	adev->gfx.gfx_off_req_count = 1;
4269 	adev->gfx.gfx_off_residency = 0;
4270 	adev->gfx.gfx_off_entrycount = 0;
4271 	adev->pm.ac_power = power_supply_is_system_supplied() > 0;
4272 
4273 	atomic_set(&adev->throttling_logging_enabled, 1);
4274 	/*
4275 	 * If throttling continues, logging will be performed every minute
4276 	 * to avoid log flooding. "-1" is subtracted since the thermal
4277 	 * throttling interrupt comes every second. Thus, the total logging
4278 	 * interval is 59 seconds(retelimited printk interval) + 1(waiting
4279 	 * for throttling interrupt) = 60 seconds.
4280 	 */
4281 	ratelimit_state_init(&adev->throttling_logging_rs, (60 - 1) * HZ, 1);
4282 	ratelimit_state_init(&adev->virt.ras_telemetry_rs, 5 * HZ, 1);
4283 
4284 	ratelimit_set_flags(&adev->throttling_logging_rs, RATELIMIT_MSG_ON_RELEASE);
4285 	ratelimit_set_flags(&adev->virt.ras_telemetry_rs, RATELIMIT_MSG_ON_RELEASE);
4286 
4287 	/* Registers mapping */
4288 	/* TODO: block userspace mapping of io register */
4289 	if (adev->asic_type >= CHIP_BONAIRE) {
4290 		adev->rmmio_base = pci_resource_start(adev->pdev, 5);
4291 		adev->rmmio_size = pci_resource_len(adev->pdev, 5);
4292 	} else {
4293 		adev->rmmio_base = pci_resource_start(adev->pdev, 2);
4294 		adev->rmmio_size = pci_resource_len(adev->pdev, 2);
4295 	}
4296 
4297 	for (i = 0; i < AMD_IP_BLOCK_TYPE_NUM; i++)
4298 		atomic_set(&adev->pm.pwr_state[i], POWER_STATE_UNKNOWN);
4299 
4300 	adev->rmmio = ioremap(adev->rmmio_base, adev->rmmio_size);
4301 	if (!adev->rmmio)
4302 		return -ENOMEM;
4303 
4304 	DRM_INFO("register mmio base: 0x%08X\n", (uint32_t)adev->rmmio_base);
4305 	DRM_INFO("register mmio size: %u\n", (unsigned int)adev->rmmio_size);
4306 
4307 	/*
4308 	 * Reset domain needs to be present early, before XGMI hive discovered
4309 	 * (if any) and intitialized to use reset sem and in_gpu reset flag
4310 	 * early on during init and before calling to RREG32.
4311 	 */
4312 	adev->reset_domain = amdgpu_reset_create_reset_domain(SINGLE_DEVICE, "amdgpu-reset-dev");
4313 	if (!adev->reset_domain)
4314 		return -ENOMEM;
4315 
4316 	/* detect hw virtualization here */
4317 	amdgpu_detect_virtualization(adev);
4318 
4319 	amdgpu_device_get_pcie_info(adev);
4320 
4321 	r = amdgpu_device_get_job_timeout_settings(adev);
4322 	if (r) {
4323 		dev_err(adev->dev, "invalid lockup_timeout parameter syntax\n");
4324 		return r;
4325 	}
4326 
4327 	amdgpu_device_set_mcbp(adev);
4328 
4329 	/*
4330 	 * By default, use default mode where all blocks are expected to be
4331 	 * initialized. At present a 'swinit' of blocks is required to be
4332 	 * completed before the need for a different level is detected.
4333 	 */
4334 	amdgpu_set_init_level(adev, AMDGPU_INIT_LEVEL_DEFAULT);
4335 	/* early init functions */
4336 	r = amdgpu_device_ip_early_init(adev);
4337 	if (r)
4338 		return r;
4339 
4340 	/* Get rid of things like offb */
4341 	r = aperture_remove_conflicting_pci_devices(adev->pdev, amdgpu_kms_driver.name);
4342 	if (r)
4343 		return r;
4344 
4345 	/* Enable TMZ based on IP_VERSION */
4346 	amdgpu_gmc_tmz_set(adev);
4347 
4348 	if (amdgpu_sriov_vf(adev) &&
4349 	    amdgpu_ip_version(adev, GC_HWIP, 0) >= IP_VERSION(10, 3, 0))
4350 		/* VF MMIO access (except mailbox range) from CPU
4351 		 * will be blocked during sriov runtime
4352 		 */
4353 		adev->virt.caps |= AMDGPU_VF_MMIO_ACCESS_PROTECT;
4354 
4355 	amdgpu_gmc_noretry_set(adev);
4356 	/* Need to get xgmi info early to decide the reset behavior*/
4357 	if (adev->gmc.xgmi.supported) {
4358 		r = adev->gfxhub.funcs->get_xgmi_info(adev);
4359 		if (r)
4360 			return r;
4361 	}
4362 
4363 	/* enable PCIE atomic ops */
4364 	if (amdgpu_sriov_vf(adev)) {
4365 		if (adev->virt.fw_reserve.p_pf2vf)
4366 			adev->have_atomics_support = ((struct amd_sriov_msg_pf2vf_info *)
4367 						      adev->virt.fw_reserve.p_pf2vf)->pcie_atomic_ops_support_flags ==
4368 				(PCI_EXP_DEVCAP2_ATOMIC_COMP32 | PCI_EXP_DEVCAP2_ATOMIC_COMP64);
4369 	/* APUs w/ gfx9 onwards doesn't reply on PCIe atomics, rather it is a
4370 	 * internal path natively support atomics, set have_atomics_support to true.
4371 	 */
4372 	} else if ((adev->flags & AMD_IS_APU) &&
4373 		   (amdgpu_ip_version(adev, GC_HWIP, 0) >
4374 		    IP_VERSION(9, 0, 0))) {
4375 		adev->have_atomics_support = true;
4376 	} else {
4377 		adev->have_atomics_support =
4378 			!pci_enable_atomic_ops_to_root(adev->pdev,
4379 					  PCI_EXP_DEVCAP2_ATOMIC_COMP32 |
4380 					  PCI_EXP_DEVCAP2_ATOMIC_COMP64);
4381 	}
4382 
4383 	if (!adev->have_atomics_support)
4384 		dev_info(adev->dev, "PCIE atomic ops is not supported\n");
4385 
4386 	/* doorbell bar mapping and doorbell index init*/
4387 	amdgpu_doorbell_init(adev);
4388 
4389 	if (amdgpu_emu_mode == 1) {
4390 		/* post the asic on emulation mode */
4391 		emu_soc_asic_init(adev);
4392 		goto fence_driver_init;
4393 	}
4394 
4395 	amdgpu_reset_init(adev);
4396 
4397 	/* detect if we are with an SRIOV vbios */
4398 	if (adev->bios)
4399 		amdgpu_device_detect_sriov_bios(adev);
4400 
4401 	/* check if we need to reset the asic
4402 	 *  E.g., driver was not cleanly unloaded previously, etc.
4403 	 */
4404 	if (!amdgpu_sriov_vf(adev) && amdgpu_asic_need_reset_on_init(adev)) {
4405 		if (adev->gmc.xgmi.num_physical_nodes) {
4406 			dev_info(adev->dev, "Pending hive reset.\n");
4407 			amdgpu_set_init_level(adev,
4408 					      AMDGPU_INIT_LEVEL_MINIMAL_XGMI);
4409 		} else if (amdgpu_ip_version(adev, MP1_HWIP, 0) == IP_VERSION(13, 0, 10) &&
4410 				   !amdgpu_device_has_display_hardware(adev)) {
4411 					r = psp_gpu_reset(adev);
4412 		} else {
4413 				tmp = amdgpu_reset_method;
4414 				/* It should do a default reset when loading or reloading the driver,
4415 				 * regardless of the module parameter reset_method.
4416 				 */
4417 				amdgpu_reset_method = AMD_RESET_METHOD_NONE;
4418 				r = amdgpu_asic_reset(adev);
4419 				amdgpu_reset_method = tmp;
4420 		}
4421 
4422 		if (r) {
4423 		  dev_err(adev->dev, "asic reset on init failed\n");
4424 		  goto failed;
4425 		}
4426 	}
4427 
4428 	/* Post card if necessary */
4429 	if (amdgpu_device_need_post(adev)) {
4430 		if (!adev->bios) {
4431 			dev_err(adev->dev, "no vBIOS found\n");
4432 			r = -EINVAL;
4433 			goto failed;
4434 		}
4435 		DRM_INFO("GPU posting now...\n");
4436 		r = amdgpu_device_asic_init(adev);
4437 		if (r) {
4438 			dev_err(adev->dev, "gpu post error!\n");
4439 			goto failed;
4440 		}
4441 	}
4442 
4443 	if (adev->bios) {
4444 		if (adev->is_atom_fw) {
4445 			/* Initialize clocks */
4446 			r = amdgpu_atomfirmware_get_clock_info(adev);
4447 			if (r) {
4448 				dev_err(adev->dev, "amdgpu_atomfirmware_get_clock_info failed\n");
4449 				amdgpu_vf_error_put(adev, AMDGIM_ERROR_VF_ATOMBIOS_GET_CLOCK_FAIL, 0, 0);
4450 				goto failed;
4451 			}
4452 		} else {
4453 			/* Initialize clocks */
4454 			r = amdgpu_atombios_get_clock_info(adev);
4455 			if (r) {
4456 				dev_err(adev->dev, "amdgpu_atombios_get_clock_info failed\n");
4457 				amdgpu_vf_error_put(adev, AMDGIM_ERROR_VF_ATOMBIOS_GET_CLOCK_FAIL, 0, 0);
4458 				goto failed;
4459 			}
4460 			/* init i2c buses */
4461 			if (!amdgpu_device_has_dc_support(adev))
4462 				amdgpu_atombios_i2c_init(adev);
4463 		}
4464 	}
4465 
4466 fence_driver_init:
4467 	/* Fence driver */
4468 	r = amdgpu_fence_driver_sw_init(adev);
4469 	if (r) {
4470 		dev_err(adev->dev, "amdgpu_fence_driver_sw_init failed\n");
4471 		amdgpu_vf_error_put(adev, AMDGIM_ERROR_VF_FENCE_INIT_FAIL, 0, 0);
4472 		goto failed;
4473 	}
4474 
4475 	/* init the mode config */
4476 	drm_mode_config_init(adev_to_drm(adev));
4477 
4478 	r = amdgpu_device_ip_init(adev);
4479 	if (r) {
4480 		dev_err(adev->dev, "amdgpu_device_ip_init failed\n");
4481 		amdgpu_vf_error_put(adev, AMDGIM_ERROR_VF_AMDGPU_INIT_FAIL, 0, 0);
4482 		goto release_ras_con;
4483 	}
4484 
4485 	amdgpu_fence_driver_hw_init(adev);
4486 
4487 	dev_info(adev->dev,
4488 		"SE %d, SH per SE %d, CU per SH %d, active_cu_number %d\n",
4489 			adev->gfx.config.max_shader_engines,
4490 			adev->gfx.config.max_sh_per_se,
4491 			adev->gfx.config.max_cu_per_sh,
4492 			adev->gfx.cu_info.number);
4493 
4494 	adev->accel_working = true;
4495 
4496 	amdgpu_vm_check_compute_bug(adev);
4497 
4498 	/* Initialize the buffer migration limit. */
4499 	if (amdgpu_moverate >= 0)
4500 		max_MBps = amdgpu_moverate;
4501 	else
4502 		max_MBps = 8; /* Allow 8 MB/s. */
4503 	/* Get a log2 for easy divisions. */
4504 	adev->mm_stats.log2_max_MBps = ilog2(max(1u, max_MBps));
4505 
4506 	/*
4507 	 * Register gpu instance before amdgpu_device_enable_mgpu_fan_boost.
4508 	 * Otherwise the mgpu fan boost feature will be skipped due to the
4509 	 * gpu instance is counted less.
4510 	 */
4511 	amdgpu_register_gpu_instance(adev);
4512 
4513 	/* enable clockgating, etc. after ib tests, etc. since some blocks require
4514 	 * explicit gating rather than handling it automatically.
4515 	 */
4516 	if (adev->init_lvl->level != AMDGPU_INIT_LEVEL_MINIMAL_XGMI) {
4517 		r = amdgpu_device_ip_late_init(adev);
4518 		if (r) {
4519 			dev_err(adev->dev, "amdgpu_device_ip_late_init failed\n");
4520 			amdgpu_vf_error_put(adev, AMDGIM_ERROR_VF_AMDGPU_LATE_INIT_FAIL, 0, r);
4521 			goto release_ras_con;
4522 		}
4523 		/* must succeed. */
4524 		amdgpu_ras_resume(adev);
4525 		queue_delayed_work(system_wq, &adev->delayed_init_work,
4526 				   msecs_to_jiffies(AMDGPU_RESUME_MS));
4527 	}
4528 
4529 	if (amdgpu_sriov_vf(adev)) {
4530 		amdgpu_virt_release_full_gpu(adev, true);
4531 		flush_delayed_work(&adev->delayed_init_work);
4532 	}
4533 
4534 	/*
4535 	 * Place those sysfs registering after `late_init`. As some of those
4536 	 * operations performed in `late_init` might affect the sysfs
4537 	 * interfaces creating.
4538 	 */
4539 	r = amdgpu_atombios_sysfs_init(adev);
4540 	if (r)
4541 		drm_err(&adev->ddev,
4542 			"registering atombios sysfs failed (%d).\n", r);
4543 
4544 	r = amdgpu_pm_sysfs_init(adev);
4545 	if (r)
4546 		DRM_ERROR("registering pm sysfs failed (%d).\n", r);
4547 
4548 	r = amdgpu_ucode_sysfs_init(adev);
4549 	if (r) {
4550 		adev->ucode_sysfs_en = false;
4551 		DRM_ERROR("Creating firmware sysfs failed (%d).\n", r);
4552 	} else
4553 		adev->ucode_sysfs_en = true;
4554 
4555 	r = sysfs_create_files(&adev->dev->kobj, amdgpu_dev_attributes);
4556 	if (r)
4557 		dev_err(adev->dev, "Could not create amdgpu device attr\n");
4558 
4559 	r = devm_device_add_group(adev->dev, &amdgpu_board_attrs_group);
4560 	if (r)
4561 		dev_err(adev->dev,
4562 			"Could not create amdgpu board attributes\n");
4563 
4564 	amdgpu_fru_sysfs_init(adev);
4565 	amdgpu_reg_state_sysfs_init(adev);
4566 	amdgpu_xcp_cfg_sysfs_init(adev);
4567 
4568 	if (IS_ENABLED(CONFIG_PERF_EVENTS))
4569 		r = amdgpu_pmu_init(adev);
4570 	if (r)
4571 		dev_err(adev->dev, "amdgpu_pmu_init failed\n");
4572 
4573 	/* Have stored pci confspace at hand for restore in sudden PCI error */
4574 	if (amdgpu_device_cache_pci_state(adev->pdev))
4575 		pci_restore_state(pdev);
4576 
4577 	/* if we have > 1 VGA cards, then disable the amdgpu VGA resources */
4578 	/* this will fail for cards that aren't VGA class devices, just
4579 	 * ignore it
4580 	 */
4581 	if ((adev->pdev->class >> 8) == PCI_CLASS_DISPLAY_VGA)
4582 		vga_client_register(adev->pdev, amdgpu_device_vga_set_decode);
4583 
4584 	px = amdgpu_device_supports_px(ddev);
4585 
4586 	if (px || (!dev_is_removable(&adev->pdev->dev) &&
4587 				apple_gmux_detect(NULL, NULL)))
4588 		vga_switcheroo_register_client(adev->pdev,
4589 					       &amdgpu_switcheroo_ops, px);
4590 
4591 	if (px)
4592 		vga_switcheroo_init_domain_pm_ops(adev->dev, &adev->vga_pm_domain);
4593 
4594 	if (adev->init_lvl->level == AMDGPU_INIT_LEVEL_MINIMAL_XGMI)
4595 		amdgpu_xgmi_reset_on_init(adev);
4596 
4597 	amdgpu_device_check_iommu_direct_map(adev);
4598 
4599 	return 0;
4600 
4601 release_ras_con:
4602 	if (amdgpu_sriov_vf(adev))
4603 		amdgpu_virt_release_full_gpu(adev, true);
4604 
4605 	/* failed in exclusive mode due to timeout */
4606 	if (amdgpu_sriov_vf(adev) &&
4607 		!amdgpu_sriov_runtime(adev) &&
4608 		amdgpu_virt_mmio_blocked(adev) &&
4609 		!amdgpu_virt_wait_reset(adev)) {
4610 		dev_err(adev->dev, "VF exclusive mode timeout\n");
4611 		/* Don't send request since VF is inactive. */
4612 		adev->virt.caps &= ~AMDGPU_SRIOV_CAPS_RUNTIME;
4613 		adev->virt.ops = NULL;
4614 		r = -EAGAIN;
4615 	}
4616 	amdgpu_release_ras_context(adev);
4617 
4618 failed:
4619 	amdgpu_vf_error_trans_all(adev);
4620 
4621 	return r;
4622 }
4623 
4624 static void amdgpu_device_unmap_mmio(struct amdgpu_device *adev)
4625 {
4626 
4627 	/* Clear all CPU mappings pointing to this device */
4628 	unmap_mapping_range(adev->ddev.anon_inode->i_mapping, 0, 0, 1);
4629 
4630 	/* Unmap all mapped bars - Doorbell, registers and VRAM */
4631 	amdgpu_doorbell_fini(adev);
4632 
4633 	iounmap(adev->rmmio);
4634 	adev->rmmio = NULL;
4635 	if (adev->mman.aper_base_kaddr)
4636 		iounmap(adev->mman.aper_base_kaddr);
4637 	adev->mman.aper_base_kaddr = NULL;
4638 
4639 	/* Memory manager related */
4640 	if (!adev->gmc.xgmi.connected_to_cpu && !adev->gmc.is_app_apu) {
4641 		arch_phys_wc_del(adev->gmc.vram_mtrr);
4642 		arch_io_free_memtype_wc(adev->gmc.aper_base, adev->gmc.aper_size);
4643 	}
4644 }
4645 
4646 /**
4647  * amdgpu_device_fini_hw - tear down the driver
4648  *
4649  * @adev: amdgpu_device pointer
4650  *
4651  * Tear down the driver info (all asics).
4652  * Called at driver shutdown.
4653  */
4654 void amdgpu_device_fini_hw(struct amdgpu_device *adev)
4655 {
4656 	dev_info(adev->dev, "amdgpu: finishing device.\n");
4657 	flush_delayed_work(&adev->delayed_init_work);
4658 
4659 	if (adev->mman.initialized)
4660 		drain_workqueue(adev->mman.bdev.wq);
4661 	adev->shutdown = true;
4662 
4663 	/* make sure IB test finished before entering exclusive mode
4664 	 * to avoid preemption on IB test
4665 	 */
4666 	if (amdgpu_sriov_vf(adev)) {
4667 		amdgpu_virt_request_full_gpu(adev, false);
4668 		amdgpu_virt_fini_data_exchange(adev);
4669 	}
4670 
4671 	/* disable all interrupts */
4672 	amdgpu_irq_disable_all(adev);
4673 	if (adev->mode_info.mode_config_initialized) {
4674 		if (!drm_drv_uses_atomic_modeset(adev_to_drm(adev)))
4675 			drm_helper_force_disable_all(adev_to_drm(adev));
4676 		else
4677 			drm_atomic_helper_shutdown(adev_to_drm(adev));
4678 	}
4679 	amdgpu_fence_driver_hw_fini(adev);
4680 
4681 	if (adev->pm.sysfs_initialized)
4682 		amdgpu_pm_sysfs_fini(adev);
4683 	if (adev->ucode_sysfs_en)
4684 		amdgpu_ucode_sysfs_fini(adev);
4685 	sysfs_remove_files(&adev->dev->kobj, amdgpu_dev_attributes);
4686 	amdgpu_fru_sysfs_fini(adev);
4687 
4688 	amdgpu_reg_state_sysfs_fini(adev);
4689 	amdgpu_xcp_cfg_sysfs_fini(adev);
4690 
4691 	/* disable ras feature must before hw fini */
4692 	amdgpu_ras_pre_fini(adev);
4693 
4694 	amdgpu_ttm_set_buffer_funcs_status(adev, false);
4695 
4696 	amdgpu_device_ip_fini_early(adev);
4697 
4698 	amdgpu_irq_fini_hw(adev);
4699 
4700 	if (adev->mman.initialized)
4701 		ttm_device_clear_dma_mappings(&adev->mman.bdev);
4702 
4703 	amdgpu_gart_dummy_page_fini(adev);
4704 
4705 	if (drm_dev_is_unplugged(adev_to_drm(adev)))
4706 		amdgpu_device_unmap_mmio(adev);
4707 
4708 }
4709 
4710 void amdgpu_device_fini_sw(struct amdgpu_device *adev)
4711 {
4712 	int idx;
4713 	bool px;
4714 
4715 	amdgpu_device_ip_fini(adev);
4716 	amdgpu_fence_driver_sw_fini(adev);
4717 	amdgpu_ucode_release(&adev->firmware.gpu_info_fw);
4718 	adev->accel_working = false;
4719 	dma_fence_put(rcu_dereference_protected(adev->gang_submit, true));
4720 
4721 	amdgpu_reset_fini(adev);
4722 
4723 	/* free i2c buses */
4724 	if (!amdgpu_device_has_dc_support(adev))
4725 		amdgpu_i2c_fini(adev);
4726 
4727 	if (amdgpu_emu_mode != 1)
4728 		amdgpu_atombios_fini(adev);
4729 
4730 	kfree(adev->bios);
4731 	adev->bios = NULL;
4732 
4733 	kfree(adev->fru_info);
4734 	adev->fru_info = NULL;
4735 
4736 	px = amdgpu_device_supports_px(adev_to_drm(adev));
4737 
4738 	if (px || (!dev_is_removable(&adev->pdev->dev) &&
4739 				apple_gmux_detect(NULL, NULL)))
4740 		vga_switcheroo_unregister_client(adev->pdev);
4741 
4742 	if (px)
4743 		vga_switcheroo_fini_domain_pm_ops(adev->dev);
4744 
4745 	if ((adev->pdev->class >> 8) == PCI_CLASS_DISPLAY_VGA)
4746 		vga_client_unregister(adev->pdev);
4747 
4748 	if (drm_dev_enter(adev_to_drm(adev), &idx)) {
4749 
4750 		iounmap(adev->rmmio);
4751 		adev->rmmio = NULL;
4752 		amdgpu_doorbell_fini(adev);
4753 		drm_dev_exit(idx);
4754 	}
4755 
4756 	if (IS_ENABLED(CONFIG_PERF_EVENTS))
4757 		amdgpu_pmu_fini(adev);
4758 	if (adev->mman.discovery_bin)
4759 		amdgpu_discovery_fini(adev);
4760 
4761 	amdgpu_reset_put_reset_domain(adev->reset_domain);
4762 	adev->reset_domain = NULL;
4763 
4764 	kfree(adev->pci_state);
4765 
4766 }
4767 
4768 /**
4769  * amdgpu_device_evict_resources - evict device resources
4770  * @adev: amdgpu device object
4771  *
4772  * Evicts all ttm device resources(vram BOs, gart table) from the lru list
4773  * of the vram memory type. Mainly used for evicting device resources
4774  * at suspend time.
4775  *
4776  */
4777 static int amdgpu_device_evict_resources(struct amdgpu_device *adev)
4778 {
4779 	int ret;
4780 
4781 	/* No need to evict vram on APUs for suspend to ram or s2idle */
4782 	if ((adev->in_s3 || adev->in_s0ix) && (adev->flags & AMD_IS_APU))
4783 		return 0;
4784 
4785 	ret = amdgpu_ttm_evict_resources(adev, TTM_PL_VRAM);
4786 	if (ret)
4787 		DRM_WARN("evicting device resources failed\n");
4788 	return ret;
4789 }
4790 
4791 /*
4792  * Suspend & resume.
4793  */
4794 /**
4795  * amdgpu_device_prepare - prepare for device suspend
4796  *
4797  * @dev: drm dev pointer
4798  *
4799  * Prepare to put the hw in the suspend state (all asics).
4800  * Returns 0 for success or an error on failure.
4801  * Called at driver suspend.
4802  */
4803 int amdgpu_device_prepare(struct drm_device *dev)
4804 {
4805 	struct amdgpu_device *adev = drm_to_adev(dev);
4806 	int i, r;
4807 
4808 	amdgpu_choose_low_power_state(adev);
4809 
4810 	if (dev->switch_power_state == DRM_SWITCH_POWER_OFF)
4811 		return 0;
4812 
4813 	/* Evict the majority of BOs before starting suspend sequence */
4814 	r = amdgpu_device_evict_resources(adev);
4815 	if (r)
4816 		goto unprepare;
4817 
4818 	flush_delayed_work(&adev->gfx.gfx_off_delay_work);
4819 
4820 	for (i = 0; i < adev->num_ip_blocks; i++) {
4821 		if (!adev->ip_blocks[i].status.valid)
4822 			continue;
4823 		if (!adev->ip_blocks[i].version->funcs->prepare_suspend)
4824 			continue;
4825 		r = adev->ip_blocks[i].version->funcs->prepare_suspend(&adev->ip_blocks[i]);
4826 		if (r)
4827 			goto unprepare;
4828 	}
4829 
4830 	return 0;
4831 
4832 unprepare:
4833 	adev->in_s0ix = adev->in_s3 = false;
4834 
4835 	return r;
4836 }
4837 
4838 /**
4839  * amdgpu_device_suspend - initiate device suspend
4840  *
4841  * @dev: drm dev pointer
4842  * @notify_clients: notify in-kernel DRM clients
4843  *
4844  * Puts the hw in the suspend state (all asics).
4845  * Returns 0 for success or an error on failure.
4846  * Called at driver suspend.
4847  */
4848 int amdgpu_device_suspend(struct drm_device *dev, bool notify_clients)
4849 {
4850 	struct amdgpu_device *adev = drm_to_adev(dev);
4851 	int r = 0;
4852 
4853 	if (dev->switch_power_state == DRM_SWITCH_POWER_OFF)
4854 		return 0;
4855 
4856 	adev->in_suspend = true;
4857 
4858 	if (amdgpu_sriov_vf(adev)) {
4859 		amdgpu_virt_fini_data_exchange(adev);
4860 		r = amdgpu_virt_request_full_gpu(adev, false);
4861 		if (r)
4862 			return r;
4863 	}
4864 
4865 	if (amdgpu_acpi_smart_shift_update(dev, AMDGPU_SS_DEV_D3))
4866 		DRM_WARN("smart shift update failed\n");
4867 
4868 	if (notify_clients)
4869 		drm_client_dev_suspend(adev_to_drm(adev), false);
4870 
4871 	cancel_delayed_work_sync(&adev->delayed_init_work);
4872 
4873 	amdgpu_ras_suspend(adev);
4874 
4875 	amdgpu_device_ip_suspend_phase1(adev);
4876 
4877 	if (!adev->in_s0ix)
4878 		amdgpu_amdkfd_suspend(adev, adev->in_runpm);
4879 
4880 	r = amdgpu_device_evict_resources(adev);
4881 	if (r)
4882 		return r;
4883 
4884 	amdgpu_ttm_set_buffer_funcs_status(adev, false);
4885 
4886 	amdgpu_fence_driver_hw_fini(adev);
4887 
4888 	amdgpu_device_ip_suspend_phase2(adev);
4889 
4890 	if (amdgpu_sriov_vf(adev))
4891 		amdgpu_virt_release_full_gpu(adev, false);
4892 
4893 	r = amdgpu_dpm_notify_rlc_state(adev, false);
4894 	if (r)
4895 		return r;
4896 
4897 	return 0;
4898 }
4899 
4900 /**
4901  * amdgpu_device_resume - initiate device resume
4902  *
4903  * @dev: drm dev pointer
4904  * @notify_clients: notify in-kernel DRM clients
4905  *
4906  * Bring the hw back to operating state (all asics).
4907  * Returns 0 for success or an error on failure.
4908  * Called at driver resume.
4909  */
4910 int amdgpu_device_resume(struct drm_device *dev, bool notify_clients)
4911 {
4912 	struct amdgpu_device *adev = drm_to_adev(dev);
4913 	int r = 0;
4914 
4915 	if (amdgpu_sriov_vf(adev)) {
4916 		r = amdgpu_virt_request_full_gpu(adev, true);
4917 		if (r)
4918 			return r;
4919 	}
4920 
4921 	if (dev->switch_power_state == DRM_SWITCH_POWER_OFF)
4922 		return 0;
4923 
4924 	if (adev->in_s0ix)
4925 		amdgpu_dpm_gfx_state_change(adev, sGpuChangeState_D0Entry);
4926 
4927 	/* post card */
4928 	if (amdgpu_device_need_post(adev)) {
4929 		r = amdgpu_device_asic_init(adev);
4930 		if (r)
4931 			dev_err(adev->dev, "amdgpu asic init failed\n");
4932 	}
4933 
4934 	r = amdgpu_device_ip_resume(adev);
4935 
4936 	if (r) {
4937 		dev_err(adev->dev, "amdgpu_device_ip_resume failed (%d).\n", r);
4938 		goto exit;
4939 	}
4940 
4941 	if (!adev->in_s0ix) {
4942 		r = amdgpu_amdkfd_resume(adev, adev->in_runpm);
4943 		if (r)
4944 			goto exit;
4945 	}
4946 
4947 	r = amdgpu_device_ip_late_init(adev);
4948 	if (r)
4949 		goto exit;
4950 
4951 	queue_delayed_work(system_wq, &adev->delayed_init_work,
4952 			   msecs_to_jiffies(AMDGPU_RESUME_MS));
4953 exit:
4954 	if (amdgpu_sriov_vf(adev)) {
4955 		amdgpu_virt_init_data_exchange(adev);
4956 		amdgpu_virt_release_full_gpu(adev, true);
4957 	}
4958 
4959 	if (r)
4960 		return r;
4961 
4962 	/* Make sure IB tests flushed */
4963 	flush_delayed_work(&adev->delayed_init_work);
4964 
4965 	if (notify_clients)
4966 		drm_client_dev_resume(adev_to_drm(adev), false);
4967 
4968 	amdgpu_ras_resume(adev);
4969 
4970 	if (adev->mode_info.num_crtc) {
4971 		/*
4972 		 * Most of the connector probing functions try to acquire runtime pm
4973 		 * refs to ensure that the GPU is powered on when connector polling is
4974 		 * performed. Since we're calling this from a runtime PM callback,
4975 		 * trying to acquire rpm refs will cause us to deadlock.
4976 		 *
4977 		 * Since we're guaranteed to be holding the rpm lock, it's safe to
4978 		 * temporarily disable the rpm helpers so this doesn't deadlock us.
4979 		 */
4980 #ifdef CONFIG_PM
4981 		dev->dev->power.disable_depth++;
4982 #endif
4983 		if (!adev->dc_enabled)
4984 			drm_helper_hpd_irq_event(dev);
4985 		else
4986 			drm_kms_helper_hotplug_event(dev);
4987 #ifdef CONFIG_PM
4988 		dev->dev->power.disable_depth--;
4989 #endif
4990 	}
4991 	adev->in_suspend = false;
4992 
4993 	if (adev->enable_mes)
4994 		amdgpu_mes_self_test(adev);
4995 
4996 	if (amdgpu_acpi_smart_shift_update(dev, AMDGPU_SS_DEV_D0))
4997 		DRM_WARN("smart shift update failed\n");
4998 
4999 	return 0;
5000 }
5001 
5002 /**
5003  * amdgpu_device_ip_check_soft_reset - did soft reset succeed
5004  *
5005  * @adev: amdgpu_device pointer
5006  *
5007  * The list of all the hardware IPs that make up the asic is walked and
5008  * the check_soft_reset callbacks are run.  check_soft_reset determines
5009  * if the asic is still hung or not.
5010  * Returns true if any of the IPs are still in a hung state, false if not.
5011  */
5012 static bool amdgpu_device_ip_check_soft_reset(struct amdgpu_device *adev)
5013 {
5014 	int i;
5015 	bool asic_hang = false;
5016 
5017 	if (amdgpu_sriov_vf(adev))
5018 		return true;
5019 
5020 	if (amdgpu_asic_need_full_reset(adev))
5021 		return true;
5022 
5023 	for (i = 0; i < adev->num_ip_blocks; i++) {
5024 		if (!adev->ip_blocks[i].status.valid)
5025 			continue;
5026 		if (adev->ip_blocks[i].version->funcs->check_soft_reset)
5027 			adev->ip_blocks[i].status.hang =
5028 				adev->ip_blocks[i].version->funcs->check_soft_reset(
5029 					&adev->ip_blocks[i]);
5030 		if (adev->ip_blocks[i].status.hang) {
5031 			dev_info(adev->dev, "IP block:%s is hung!\n", adev->ip_blocks[i].version->funcs->name);
5032 			asic_hang = true;
5033 		}
5034 	}
5035 	return asic_hang;
5036 }
5037 
5038 /**
5039  * amdgpu_device_ip_pre_soft_reset - prepare for soft reset
5040  *
5041  * @adev: amdgpu_device pointer
5042  *
5043  * The list of all the hardware IPs that make up the asic is walked and the
5044  * pre_soft_reset callbacks are run if the block is hung.  pre_soft_reset
5045  * handles any IP specific hardware or software state changes that are
5046  * necessary for a soft reset to succeed.
5047  * Returns 0 on success, negative error code on failure.
5048  */
5049 static int amdgpu_device_ip_pre_soft_reset(struct amdgpu_device *adev)
5050 {
5051 	int i, r = 0;
5052 
5053 	for (i = 0; i < adev->num_ip_blocks; i++) {
5054 		if (!adev->ip_blocks[i].status.valid)
5055 			continue;
5056 		if (adev->ip_blocks[i].status.hang &&
5057 		    adev->ip_blocks[i].version->funcs->pre_soft_reset) {
5058 			r = adev->ip_blocks[i].version->funcs->pre_soft_reset(&adev->ip_blocks[i]);
5059 			if (r)
5060 				return r;
5061 		}
5062 	}
5063 
5064 	return 0;
5065 }
5066 
5067 /**
5068  * amdgpu_device_ip_need_full_reset - check if a full asic reset is needed
5069  *
5070  * @adev: amdgpu_device pointer
5071  *
5072  * Some hardware IPs cannot be soft reset.  If they are hung, a full gpu
5073  * reset is necessary to recover.
5074  * Returns true if a full asic reset is required, false if not.
5075  */
5076 static bool amdgpu_device_ip_need_full_reset(struct amdgpu_device *adev)
5077 {
5078 	int i;
5079 
5080 	if (amdgpu_asic_need_full_reset(adev))
5081 		return true;
5082 
5083 	for (i = 0; i < adev->num_ip_blocks; i++) {
5084 		if (!adev->ip_blocks[i].status.valid)
5085 			continue;
5086 		if ((adev->ip_blocks[i].version->type == AMD_IP_BLOCK_TYPE_GMC) ||
5087 		    (adev->ip_blocks[i].version->type == AMD_IP_BLOCK_TYPE_SMC) ||
5088 		    (adev->ip_blocks[i].version->type == AMD_IP_BLOCK_TYPE_ACP) ||
5089 		    (adev->ip_blocks[i].version->type == AMD_IP_BLOCK_TYPE_DCE) ||
5090 		     adev->ip_blocks[i].version->type == AMD_IP_BLOCK_TYPE_PSP) {
5091 			if (adev->ip_blocks[i].status.hang) {
5092 				dev_info(adev->dev, "Some block need full reset!\n");
5093 				return true;
5094 			}
5095 		}
5096 	}
5097 	return false;
5098 }
5099 
5100 /**
5101  * amdgpu_device_ip_soft_reset - do a soft reset
5102  *
5103  * @adev: amdgpu_device pointer
5104  *
5105  * The list of all the hardware IPs that make up the asic is walked and the
5106  * soft_reset callbacks are run if the block is hung.  soft_reset handles any
5107  * IP specific hardware or software state changes that are necessary to soft
5108  * reset the IP.
5109  * Returns 0 on success, negative error code on failure.
5110  */
5111 static int amdgpu_device_ip_soft_reset(struct amdgpu_device *adev)
5112 {
5113 	int i, r = 0;
5114 
5115 	for (i = 0; i < adev->num_ip_blocks; i++) {
5116 		if (!adev->ip_blocks[i].status.valid)
5117 			continue;
5118 		if (adev->ip_blocks[i].status.hang &&
5119 		    adev->ip_blocks[i].version->funcs->soft_reset) {
5120 			r = adev->ip_blocks[i].version->funcs->soft_reset(&adev->ip_blocks[i]);
5121 			if (r)
5122 				return r;
5123 		}
5124 	}
5125 
5126 	return 0;
5127 }
5128 
5129 /**
5130  * amdgpu_device_ip_post_soft_reset - clean up from soft reset
5131  *
5132  * @adev: amdgpu_device pointer
5133  *
5134  * The list of all the hardware IPs that make up the asic is walked and the
5135  * post_soft_reset callbacks are run if the asic was hung.  post_soft_reset
5136  * handles any IP specific hardware or software state changes that are
5137  * necessary after the IP has been soft reset.
5138  * Returns 0 on success, negative error code on failure.
5139  */
5140 static int amdgpu_device_ip_post_soft_reset(struct amdgpu_device *adev)
5141 {
5142 	int i, r = 0;
5143 
5144 	for (i = 0; i < adev->num_ip_blocks; i++) {
5145 		if (!adev->ip_blocks[i].status.valid)
5146 			continue;
5147 		if (adev->ip_blocks[i].status.hang &&
5148 		    adev->ip_blocks[i].version->funcs->post_soft_reset)
5149 			r = adev->ip_blocks[i].version->funcs->post_soft_reset(&adev->ip_blocks[i]);
5150 		if (r)
5151 			return r;
5152 	}
5153 
5154 	return 0;
5155 }
5156 
5157 /**
5158  * amdgpu_device_reset_sriov - reset ASIC for SR-IOV vf
5159  *
5160  * @adev: amdgpu_device pointer
5161  * @reset_context: amdgpu reset context pointer
5162  *
5163  * do VF FLR and reinitialize Asic
5164  * return 0 means succeeded otherwise failed
5165  */
5166 static int amdgpu_device_reset_sriov(struct amdgpu_device *adev,
5167 				     struct amdgpu_reset_context *reset_context)
5168 {
5169 	int r;
5170 	struct amdgpu_hive_info *hive = NULL;
5171 
5172 	if (test_bit(AMDGPU_HOST_FLR, &reset_context->flags)) {
5173 		if (!amdgpu_ras_get_fed_status(adev))
5174 			amdgpu_virt_ready_to_reset(adev);
5175 		amdgpu_virt_wait_reset(adev);
5176 		clear_bit(AMDGPU_HOST_FLR, &reset_context->flags);
5177 		r = amdgpu_virt_request_full_gpu(adev, true);
5178 	} else {
5179 		r = amdgpu_virt_reset_gpu(adev);
5180 	}
5181 	if (r)
5182 		return r;
5183 
5184 	amdgpu_ras_set_fed(adev, false);
5185 	amdgpu_irq_gpu_reset_resume_helper(adev);
5186 
5187 	/* some sw clean up VF needs to do before recover */
5188 	amdgpu_virt_post_reset(adev);
5189 
5190 	/* Resume IP prior to SMC */
5191 	r = amdgpu_device_ip_reinit_early_sriov(adev);
5192 	if (r)
5193 		return r;
5194 
5195 	amdgpu_virt_init_data_exchange(adev);
5196 
5197 	r = amdgpu_device_fw_loading(adev);
5198 	if (r)
5199 		return r;
5200 
5201 	/* now we are okay to resume SMC/CP/SDMA */
5202 	r = amdgpu_device_ip_reinit_late_sriov(adev);
5203 	if (r)
5204 		return r;
5205 
5206 	hive = amdgpu_get_xgmi_hive(adev);
5207 	/* Update PSP FW topology after reset */
5208 	if (hive && adev->gmc.xgmi.num_physical_nodes > 1)
5209 		r = amdgpu_xgmi_update_topology(hive, adev);
5210 	if (hive)
5211 		amdgpu_put_xgmi_hive(hive);
5212 	if (r)
5213 		return r;
5214 
5215 	r = amdgpu_ib_ring_tests(adev);
5216 	if (r)
5217 		return r;
5218 
5219 	if (adev->virt.gim_feature & AMDGIM_FEATURE_GIM_FLR_VRAMLOST)
5220 		amdgpu_inc_vram_lost(adev);
5221 
5222 	/* need to be called during full access so we can't do it later like
5223 	 * bare-metal does.
5224 	 */
5225 	amdgpu_amdkfd_post_reset(adev);
5226 	amdgpu_virt_release_full_gpu(adev, true);
5227 
5228 	/* Aldebaran and gfx_11_0_3 support ras in SRIOV, so need resume ras during reset */
5229 	if (amdgpu_ip_version(adev, GC_HWIP, 0) == IP_VERSION(9, 4, 2) ||
5230 	    amdgpu_ip_version(adev, GC_HWIP, 0) == IP_VERSION(9, 4, 3) ||
5231 	    amdgpu_ip_version(adev, GC_HWIP, 0) == IP_VERSION(9, 4, 4) ||
5232 	    amdgpu_ip_version(adev, GC_HWIP, 0) == IP_VERSION(11, 0, 3))
5233 		amdgpu_ras_resume(adev);
5234 
5235 	amdgpu_virt_ras_telemetry_post_reset(adev);
5236 
5237 	return 0;
5238 }
5239 
5240 /**
5241  * amdgpu_device_has_job_running - check if there is any job in mirror list
5242  *
5243  * @adev: amdgpu_device pointer
5244  *
5245  * check if there is any job in mirror list
5246  */
5247 bool amdgpu_device_has_job_running(struct amdgpu_device *adev)
5248 {
5249 	int i;
5250 	struct drm_sched_job *job;
5251 
5252 	for (i = 0; i < AMDGPU_MAX_RINGS; ++i) {
5253 		struct amdgpu_ring *ring = adev->rings[i];
5254 
5255 		if (!amdgpu_ring_sched_ready(ring))
5256 			continue;
5257 
5258 		spin_lock(&ring->sched.job_list_lock);
5259 		job = list_first_entry_or_null(&ring->sched.pending_list,
5260 					       struct drm_sched_job, list);
5261 		spin_unlock(&ring->sched.job_list_lock);
5262 		if (job)
5263 			return true;
5264 	}
5265 	return false;
5266 }
5267 
5268 /**
5269  * amdgpu_device_should_recover_gpu - check if we should try GPU recovery
5270  *
5271  * @adev: amdgpu_device pointer
5272  *
5273  * Check amdgpu_gpu_recovery and SRIOV status to see if we should try to recover
5274  * a hung GPU.
5275  */
5276 bool amdgpu_device_should_recover_gpu(struct amdgpu_device *adev)
5277 {
5278 
5279 	if (amdgpu_gpu_recovery == 0)
5280 		goto disabled;
5281 
5282 	/* Skip soft reset check in fatal error mode */
5283 	if (!amdgpu_ras_is_poison_mode_supported(adev))
5284 		return true;
5285 
5286 	if (amdgpu_sriov_vf(adev))
5287 		return true;
5288 
5289 	if (amdgpu_gpu_recovery == -1) {
5290 		switch (adev->asic_type) {
5291 #ifdef CONFIG_DRM_AMDGPU_SI
5292 		case CHIP_VERDE:
5293 		case CHIP_TAHITI:
5294 		case CHIP_PITCAIRN:
5295 		case CHIP_OLAND:
5296 		case CHIP_HAINAN:
5297 #endif
5298 #ifdef CONFIG_DRM_AMDGPU_CIK
5299 		case CHIP_KAVERI:
5300 		case CHIP_KABINI:
5301 		case CHIP_MULLINS:
5302 #endif
5303 		case CHIP_CARRIZO:
5304 		case CHIP_STONEY:
5305 		case CHIP_CYAN_SKILLFISH:
5306 			goto disabled;
5307 		default:
5308 			break;
5309 		}
5310 	}
5311 
5312 	return true;
5313 
5314 disabled:
5315 		dev_info(adev->dev, "GPU recovery disabled.\n");
5316 		return false;
5317 }
5318 
5319 int amdgpu_device_mode1_reset(struct amdgpu_device *adev)
5320 {
5321 	u32 i;
5322 	int ret = 0;
5323 
5324 	amdgpu_atombios_scratch_regs_engine_hung(adev, true);
5325 
5326 	dev_info(adev->dev, "GPU mode1 reset\n");
5327 
5328 	/* Cache the state before bus master disable. The saved config space
5329 	 * values are used in other cases like restore after mode-2 reset.
5330 	 */
5331 	amdgpu_device_cache_pci_state(adev->pdev);
5332 
5333 	/* disable BM */
5334 	pci_clear_master(adev->pdev);
5335 
5336 	if (amdgpu_dpm_is_mode1_reset_supported(adev)) {
5337 		dev_info(adev->dev, "GPU smu mode1 reset\n");
5338 		ret = amdgpu_dpm_mode1_reset(adev);
5339 	} else {
5340 		dev_info(adev->dev, "GPU psp mode1 reset\n");
5341 		ret = psp_gpu_reset(adev);
5342 	}
5343 
5344 	if (ret)
5345 		goto mode1_reset_failed;
5346 
5347 	amdgpu_device_load_pci_state(adev->pdev);
5348 	ret = amdgpu_psp_wait_for_bootloader(adev);
5349 	if (ret)
5350 		goto mode1_reset_failed;
5351 
5352 	/* wait for asic to come out of reset */
5353 	for (i = 0; i < adev->usec_timeout; i++) {
5354 		u32 memsize = adev->nbio.funcs->get_memsize(adev);
5355 
5356 		if (memsize != 0xffffffff)
5357 			break;
5358 		udelay(1);
5359 	}
5360 
5361 	if (i >= adev->usec_timeout) {
5362 		ret = -ETIMEDOUT;
5363 		goto mode1_reset_failed;
5364 	}
5365 
5366 	amdgpu_atombios_scratch_regs_engine_hung(adev, false);
5367 
5368 	return 0;
5369 
5370 mode1_reset_failed:
5371 	dev_err(adev->dev, "GPU mode1 reset failed\n");
5372 	return ret;
5373 }
5374 
5375 int amdgpu_device_pre_asic_reset(struct amdgpu_device *adev,
5376 				 struct amdgpu_reset_context *reset_context)
5377 {
5378 	int i, r = 0;
5379 	struct amdgpu_job *job = NULL;
5380 	struct amdgpu_device *tmp_adev = reset_context->reset_req_dev;
5381 	bool need_full_reset =
5382 		test_bit(AMDGPU_NEED_FULL_RESET, &reset_context->flags);
5383 
5384 	if (reset_context->reset_req_dev == adev)
5385 		job = reset_context->job;
5386 
5387 	if (amdgpu_sriov_vf(adev))
5388 		amdgpu_virt_pre_reset(adev);
5389 
5390 	amdgpu_fence_driver_isr_toggle(adev, true);
5391 
5392 	/* block all schedulers and reset given job's ring */
5393 	for (i = 0; i < AMDGPU_MAX_RINGS; ++i) {
5394 		struct amdgpu_ring *ring = adev->rings[i];
5395 
5396 		if (!amdgpu_ring_sched_ready(ring))
5397 			continue;
5398 
5399 		/* Clear job fence from fence drv to avoid force_completion
5400 		 * leave NULL and vm flush fence in fence drv
5401 		 */
5402 		amdgpu_fence_driver_clear_job_fences(ring);
5403 
5404 		/* after all hw jobs are reset, hw fence is meaningless, so force_completion */
5405 		amdgpu_fence_driver_force_completion(ring);
5406 	}
5407 
5408 	amdgpu_fence_driver_isr_toggle(adev, false);
5409 
5410 	if (job && job->vm)
5411 		drm_sched_increase_karma(&job->base);
5412 
5413 	r = amdgpu_reset_prepare_hwcontext(adev, reset_context);
5414 	/* If reset handler not implemented, continue; otherwise return */
5415 	if (r == -EOPNOTSUPP)
5416 		r = 0;
5417 	else
5418 		return r;
5419 
5420 	/* Don't suspend on bare metal if we are not going to HW reset the ASIC */
5421 	if (!amdgpu_sriov_vf(adev)) {
5422 
5423 		if (!need_full_reset)
5424 			need_full_reset = amdgpu_device_ip_need_full_reset(adev);
5425 
5426 		if (!need_full_reset && amdgpu_gpu_recovery &&
5427 		    amdgpu_device_ip_check_soft_reset(adev)) {
5428 			amdgpu_device_ip_pre_soft_reset(adev);
5429 			r = amdgpu_device_ip_soft_reset(adev);
5430 			amdgpu_device_ip_post_soft_reset(adev);
5431 			if (r || amdgpu_device_ip_check_soft_reset(adev)) {
5432 				dev_info(adev->dev, "soft reset failed, will fallback to full reset!\n");
5433 				need_full_reset = true;
5434 			}
5435 		}
5436 
5437 		if (!test_bit(AMDGPU_SKIP_COREDUMP, &reset_context->flags)) {
5438 			dev_info(tmp_adev->dev, "Dumping IP State\n");
5439 			/* Trigger ip dump before we reset the asic */
5440 			for (i = 0; i < tmp_adev->num_ip_blocks; i++)
5441 				if (tmp_adev->ip_blocks[i].version->funcs->dump_ip_state)
5442 					tmp_adev->ip_blocks[i].version->funcs
5443 						->dump_ip_state((void *)&tmp_adev->ip_blocks[i]);
5444 			dev_info(tmp_adev->dev, "Dumping IP State Completed\n");
5445 		}
5446 
5447 		if (need_full_reset)
5448 			r = amdgpu_device_ip_suspend(adev);
5449 		if (need_full_reset)
5450 			set_bit(AMDGPU_NEED_FULL_RESET, &reset_context->flags);
5451 		else
5452 			clear_bit(AMDGPU_NEED_FULL_RESET,
5453 				  &reset_context->flags);
5454 	}
5455 
5456 	return r;
5457 }
5458 
5459 int amdgpu_device_reinit_after_reset(struct amdgpu_reset_context *reset_context)
5460 {
5461 	struct list_head *device_list_handle;
5462 	bool full_reset, vram_lost = false;
5463 	struct amdgpu_device *tmp_adev;
5464 	int r, init_level;
5465 
5466 	device_list_handle = reset_context->reset_device_list;
5467 
5468 	if (!device_list_handle)
5469 		return -EINVAL;
5470 
5471 	full_reset = test_bit(AMDGPU_NEED_FULL_RESET, &reset_context->flags);
5472 
5473 	/**
5474 	 * If it's reset on init, it's default init level, otherwise keep level
5475 	 * as recovery level.
5476 	 */
5477 	if (reset_context->method == AMD_RESET_METHOD_ON_INIT)
5478 			init_level = AMDGPU_INIT_LEVEL_DEFAULT;
5479 	else
5480 			init_level = AMDGPU_INIT_LEVEL_RESET_RECOVERY;
5481 
5482 	r = 0;
5483 	list_for_each_entry(tmp_adev, device_list_handle, reset_list) {
5484 		amdgpu_set_init_level(tmp_adev, init_level);
5485 		if (full_reset) {
5486 			/* post card */
5487 			amdgpu_ras_set_fed(tmp_adev, false);
5488 			r = amdgpu_device_asic_init(tmp_adev);
5489 			if (r) {
5490 				dev_warn(tmp_adev->dev, "asic atom init failed!");
5491 			} else {
5492 				dev_info(tmp_adev->dev, "GPU reset succeeded, trying to resume\n");
5493 
5494 				r = amdgpu_device_ip_resume_phase1(tmp_adev);
5495 				if (r)
5496 					goto out;
5497 
5498 				vram_lost = amdgpu_device_check_vram_lost(tmp_adev);
5499 
5500 				if (!test_bit(AMDGPU_SKIP_COREDUMP, &reset_context->flags))
5501 					amdgpu_coredump(tmp_adev, false, vram_lost, reset_context->job);
5502 
5503 				if (vram_lost) {
5504 					DRM_INFO("VRAM is lost due to GPU reset!\n");
5505 					amdgpu_inc_vram_lost(tmp_adev);
5506 				}
5507 
5508 				r = amdgpu_device_fw_loading(tmp_adev);
5509 				if (r)
5510 					return r;
5511 
5512 				r = amdgpu_xcp_restore_partition_mode(
5513 					tmp_adev->xcp_mgr);
5514 				if (r)
5515 					goto out;
5516 
5517 				r = amdgpu_device_ip_resume_phase2(tmp_adev);
5518 				if (r)
5519 					goto out;
5520 
5521 				if (tmp_adev->mman.buffer_funcs_ring->sched.ready)
5522 					amdgpu_ttm_set_buffer_funcs_status(tmp_adev, true);
5523 
5524 				r = amdgpu_device_ip_resume_phase3(tmp_adev);
5525 				if (r)
5526 					goto out;
5527 
5528 				if (vram_lost)
5529 					amdgpu_device_fill_reset_magic(tmp_adev);
5530 
5531 				/*
5532 				 * Add this ASIC as tracked as reset was already
5533 				 * complete successfully.
5534 				 */
5535 				amdgpu_register_gpu_instance(tmp_adev);
5536 
5537 				if (!reset_context->hive &&
5538 				    tmp_adev->gmc.xgmi.num_physical_nodes > 1)
5539 					amdgpu_xgmi_add_device(tmp_adev);
5540 
5541 				r = amdgpu_device_ip_late_init(tmp_adev);
5542 				if (r)
5543 					goto out;
5544 
5545 				drm_client_dev_resume(adev_to_drm(tmp_adev), false);
5546 
5547 				/*
5548 				 * The GPU enters bad state once faulty pages
5549 				 * by ECC has reached the threshold, and ras
5550 				 * recovery is scheduled next. So add one check
5551 				 * here to break recovery if it indeed exceeds
5552 				 * bad page threshold, and remind user to
5553 				 * retire this GPU or setting one bigger
5554 				 * bad_page_threshold value to fix this once
5555 				 * probing driver again.
5556 				 */
5557 				if (!amdgpu_ras_is_rma(tmp_adev)) {
5558 					/* must succeed. */
5559 					amdgpu_ras_resume(tmp_adev);
5560 				} else {
5561 					r = -EINVAL;
5562 					goto out;
5563 				}
5564 
5565 				/* Update PSP FW topology after reset */
5566 				if (reset_context->hive &&
5567 				    tmp_adev->gmc.xgmi.num_physical_nodes > 1)
5568 					r = amdgpu_xgmi_update_topology(
5569 						reset_context->hive, tmp_adev);
5570 			}
5571 		}
5572 
5573 out:
5574 		if (!r) {
5575 			/* IP init is complete now, set level as default */
5576 			amdgpu_set_init_level(tmp_adev,
5577 					      AMDGPU_INIT_LEVEL_DEFAULT);
5578 			amdgpu_irq_gpu_reset_resume_helper(tmp_adev);
5579 			r = amdgpu_ib_ring_tests(tmp_adev);
5580 			if (r) {
5581 				dev_err(tmp_adev->dev, "ib ring test failed (%d).\n", r);
5582 				r = -EAGAIN;
5583 				goto end;
5584 			}
5585 		}
5586 
5587 		if (r)
5588 			tmp_adev->asic_reset_res = r;
5589 	}
5590 
5591 end:
5592 	return r;
5593 }
5594 
5595 int amdgpu_do_asic_reset(struct list_head *device_list_handle,
5596 			 struct amdgpu_reset_context *reset_context)
5597 {
5598 	struct amdgpu_device *tmp_adev = NULL;
5599 	bool need_full_reset, skip_hw_reset;
5600 	int r = 0;
5601 
5602 	/* Try reset handler method first */
5603 	tmp_adev = list_first_entry(device_list_handle, struct amdgpu_device,
5604 				    reset_list);
5605 
5606 	reset_context->reset_device_list = device_list_handle;
5607 	r = amdgpu_reset_perform_reset(tmp_adev, reset_context);
5608 	/* If reset handler not implemented, continue; otherwise return */
5609 	if (r == -EOPNOTSUPP)
5610 		r = 0;
5611 	else
5612 		return r;
5613 
5614 	/* Reset handler not implemented, use the default method */
5615 	need_full_reset =
5616 		test_bit(AMDGPU_NEED_FULL_RESET, &reset_context->flags);
5617 	skip_hw_reset = test_bit(AMDGPU_SKIP_HW_RESET, &reset_context->flags);
5618 
5619 	/*
5620 	 * ASIC reset has to be done on all XGMI hive nodes ASAP
5621 	 * to allow proper links negotiation in FW (within 1 sec)
5622 	 */
5623 	if (!skip_hw_reset && need_full_reset) {
5624 		list_for_each_entry(tmp_adev, device_list_handle, reset_list) {
5625 			/* For XGMI run all resets in parallel to speed up the process */
5626 			if (tmp_adev->gmc.xgmi.num_physical_nodes > 1) {
5627 				if (!queue_work(system_unbound_wq,
5628 						&tmp_adev->xgmi_reset_work))
5629 					r = -EALREADY;
5630 			} else
5631 				r = amdgpu_asic_reset(tmp_adev);
5632 
5633 			if (r) {
5634 				dev_err(tmp_adev->dev,
5635 					"ASIC reset failed with error, %d for drm dev, %s",
5636 					r, adev_to_drm(tmp_adev)->unique);
5637 				goto out;
5638 			}
5639 		}
5640 
5641 		/* For XGMI wait for all resets to complete before proceed */
5642 		if (!r) {
5643 			list_for_each_entry(tmp_adev, device_list_handle,
5644 					    reset_list) {
5645 				if (tmp_adev->gmc.xgmi.num_physical_nodes > 1) {
5646 					flush_work(&tmp_adev->xgmi_reset_work);
5647 					r = tmp_adev->asic_reset_res;
5648 					if (r)
5649 						break;
5650 				}
5651 			}
5652 		}
5653 	}
5654 
5655 	if (!r && amdgpu_ras_intr_triggered()) {
5656 		list_for_each_entry(tmp_adev, device_list_handle, reset_list) {
5657 			amdgpu_ras_reset_error_count(tmp_adev,
5658 						     AMDGPU_RAS_BLOCK__MMHUB);
5659 		}
5660 
5661 		amdgpu_ras_intr_cleared();
5662 	}
5663 
5664 	r = amdgpu_device_reinit_after_reset(reset_context);
5665 	if (r == -EAGAIN)
5666 		set_bit(AMDGPU_NEED_FULL_RESET, &reset_context->flags);
5667 	else
5668 		clear_bit(AMDGPU_NEED_FULL_RESET, &reset_context->flags);
5669 
5670 out:
5671 	return r;
5672 }
5673 
5674 static void amdgpu_device_set_mp1_state(struct amdgpu_device *adev)
5675 {
5676 
5677 	switch (amdgpu_asic_reset_method(adev)) {
5678 	case AMD_RESET_METHOD_MODE1:
5679 		adev->mp1_state = PP_MP1_STATE_SHUTDOWN;
5680 		break;
5681 	case AMD_RESET_METHOD_MODE2:
5682 		adev->mp1_state = PP_MP1_STATE_RESET;
5683 		break;
5684 	default:
5685 		adev->mp1_state = PP_MP1_STATE_NONE;
5686 		break;
5687 	}
5688 }
5689 
5690 static void amdgpu_device_unset_mp1_state(struct amdgpu_device *adev)
5691 {
5692 	amdgpu_vf_error_trans_all(adev);
5693 	adev->mp1_state = PP_MP1_STATE_NONE;
5694 }
5695 
5696 static void amdgpu_device_resume_display_audio(struct amdgpu_device *adev)
5697 {
5698 	struct pci_dev *p = NULL;
5699 
5700 	p = pci_get_domain_bus_and_slot(pci_domain_nr(adev->pdev->bus),
5701 			adev->pdev->bus->number, 1);
5702 	if (p) {
5703 		pm_runtime_enable(&(p->dev));
5704 		pm_runtime_resume(&(p->dev));
5705 	}
5706 
5707 	pci_dev_put(p);
5708 }
5709 
5710 static int amdgpu_device_suspend_display_audio(struct amdgpu_device *adev)
5711 {
5712 	enum amd_reset_method reset_method;
5713 	struct pci_dev *p = NULL;
5714 	u64 expires;
5715 
5716 	/*
5717 	 * For now, only BACO and mode1 reset are confirmed
5718 	 * to suffer the audio issue without proper suspended.
5719 	 */
5720 	reset_method = amdgpu_asic_reset_method(adev);
5721 	if ((reset_method != AMD_RESET_METHOD_BACO) &&
5722 	     (reset_method != AMD_RESET_METHOD_MODE1))
5723 		return -EINVAL;
5724 
5725 	p = pci_get_domain_bus_and_slot(pci_domain_nr(adev->pdev->bus),
5726 			adev->pdev->bus->number, 1);
5727 	if (!p)
5728 		return -ENODEV;
5729 
5730 	expires = pm_runtime_autosuspend_expiration(&(p->dev));
5731 	if (!expires)
5732 		/*
5733 		 * If we cannot get the audio device autosuspend delay,
5734 		 * a fixed 4S interval will be used. Considering 3S is
5735 		 * the audio controller default autosuspend delay setting.
5736 		 * 4S used here is guaranteed to cover that.
5737 		 */
5738 		expires = ktime_get_mono_fast_ns() + NSEC_PER_SEC * 4ULL;
5739 
5740 	while (!pm_runtime_status_suspended(&(p->dev))) {
5741 		if (!pm_runtime_suspend(&(p->dev)))
5742 			break;
5743 
5744 		if (expires < ktime_get_mono_fast_ns()) {
5745 			dev_warn(adev->dev, "failed to suspend display audio\n");
5746 			pci_dev_put(p);
5747 			/* TODO: abort the succeeding gpu reset? */
5748 			return -ETIMEDOUT;
5749 		}
5750 	}
5751 
5752 	pm_runtime_disable(&(p->dev));
5753 
5754 	pci_dev_put(p);
5755 	return 0;
5756 }
5757 
5758 static inline void amdgpu_device_stop_pending_resets(struct amdgpu_device *adev)
5759 {
5760 	struct amdgpu_ras *con = amdgpu_ras_get_context(adev);
5761 
5762 #if defined(CONFIG_DEBUG_FS)
5763 	if (!amdgpu_sriov_vf(adev))
5764 		cancel_work(&adev->reset_work);
5765 #endif
5766 
5767 	if (adev->kfd.dev)
5768 		cancel_work(&adev->kfd.reset_work);
5769 
5770 	if (amdgpu_sriov_vf(adev))
5771 		cancel_work(&adev->virt.flr_work);
5772 
5773 	if (con && adev->ras_enabled)
5774 		cancel_work(&con->recovery_work);
5775 
5776 }
5777 
5778 static int amdgpu_device_health_check(struct list_head *device_list_handle)
5779 {
5780 	struct amdgpu_device *tmp_adev;
5781 	int ret = 0;
5782 	u32 status;
5783 
5784 	list_for_each_entry(tmp_adev, device_list_handle, reset_list) {
5785 		pci_read_config_dword(tmp_adev->pdev, PCI_COMMAND, &status);
5786 		if (PCI_POSSIBLE_ERROR(status)) {
5787 			dev_err(tmp_adev->dev, "device lost from bus!");
5788 			ret = -ENODEV;
5789 		}
5790 	}
5791 
5792 	return ret;
5793 }
5794 
5795 /**
5796  * amdgpu_device_gpu_recover - reset the asic and recover scheduler
5797  *
5798  * @adev: amdgpu_device pointer
5799  * @job: which job trigger hang
5800  * @reset_context: amdgpu reset context pointer
5801  *
5802  * Attempt to reset the GPU if it has hung (all asics).
5803  * Attempt to do soft-reset or full-reset and reinitialize Asic
5804  * Returns 0 for success or an error on failure.
5805  */
5806 
5807 int amdgpu_device_gpu_recover(struct amdgpu_device *adev,
5808 			      struct amdgpu_job *job,
5809 			      struct amdgpu_reset_context *reset_context)
5810 {
5811 	struct list_head device_list, *device_list_handle =  NULL;
5812 	bool job_signaled = false;
5813 	struct amdgpu_hive_info *hive = NULL;
5814 	struct amdgpu_device *tmp_adev = NULL;
5815 	int i, r = 0;
5816 	bool need_emergency_restart = false;
5817 	bool audio_suspended = false;
5818 	int retry_limit = AMDGPU_MAX_RETRY_LIMIT;
5819 
5820 	/*
5821 	 * Special case: RAS triggered and full reset isn't supported
5822 	 */
5823 	need_emergency_restart = amdgpu_ras_need_emergency_restart(adev);
5824 
5825 	/*
5826 	 * Flush RAM to disk so that after reboot
5827 	 * the user can read log and see why the system rebooted.
5828 	 */
5829 	if (need_emergency_restart && amdgpu_ras_get_context(adev) &&
5830 		amdgpu_ras_get_context(adev)->reboot) {
5831 		DRM_WARN("Emergency reboot.");
5832 
5833 		ksys_sync_helper();
5834 		emergency_restart();
5835 	}
5836 
5837 	dev_info(adev->dev, "GPU %s begin!\n",
5838 		need_emergency_restart ? "jobs stop":"reset");
5839 
5840 	if (!amdgpu_sriov_vf(adev))
5841 		hive = amdgpu_get_xgmi_hive(adev);
5842 	if (hive)
5843 		mutex_lock(&hive->hive_lock);
5844 
5845 	reset_context->job = job;
5846 	reset_context->hive = hive;
5847 	/*
5848 	 * Build list of devices to reset.
5849 	 * In case we are in XGMI hive mode, resort the device list
5850 	 * to put adev in the 1st position.
5851 	 */
5852 	INIT_LIST_HEAD(&device_list);
5853 	if (!amdgpu_sriov_vf(adev) && (adev->gmc.xgmi.num_physical_nodes > 1) && hive) {
5854 		list_for_each_entry(tmp_adev, &hive->device_list, gmc.xgmi.head) {
5855 			list_add_tail(&tmp_adev->reset_list, &device_list);
5856 			if (adev->shutdown)
5857 				tmp_adev->shutdown = true;
5858 		}
5859 		if (!list_is_first(&adev->reset_list, &device_list))
5860 			list_rotate_to_front(&adev->reset_list, &device_list);
5861 		device_list_handle = &device_list;
5862 	} else {
5863 		list_add_tail(&adev->reset_list, &device_list);
5864 		device_list_handle = &device_list;
5865 	}
5866 
5867 	if (!amdgpu_sriov_vf(adev)) {
5868 		r = amdgpu_device_health_check(device_list_handle);
5869 		if (r)
5870 			goto end_reset;
5871 	}
5872 
5873 	/* We need to lock reset domain only once both for XGMI and single device */
5874 	tmp_adev = list_first_entry(device_list_handle, struct amdgpu_device,
5875 				    reset_list);
5876 	amdgpu_device_lock_reset_domain(tmp_adev->reset_domain);
5877 
5878 	/* block all schedulers and reset given job's ring */
5879 	list_for_each_entry(tmp_adev, device_list_handle, reset_list) {
5880 
5881 		amdgpu_device_set_mp1_state(tmp_adev);
5882 
5883 		/*
5884 		 * Try to put the audio codec into suspend state
5885 		 * before gpu reset started.
5886 		 *
5887 		 * Due to the power domain of the graphics device
5888 		 * is shared with AZ power domain. Without this,
5889 		 * we may change the audio hardware from behind
5890 		 * the audio driver's back. That will trigger
5891 		 * some audio codec errors.
5892 		 */
5893 		if (!amdgpu_device_suspend_display_audio(tmp_adev))
5894 			audio_suspended = true;
5895 
5896 		amdgpu_ras_set_error_query_ready(tmp_adev, false);
5897 
5898 		cancel_delayed_work_sync(&tmp_adev->delayed_init_work);
5899 
5900 		amdgpu_amdkfd_pre_reset(tmp_adev, reset_context);
5901 
5902 		/*
5903 		 * Mark these ASICs to be reseted as untracked first
5904 		 * And add them back after reset completed
5905 		 */
5906 		amdgpu_unregister_gpu_instance(tmp_adev);
5907 
5908 		drm_client_dev_suspend(adev_to_drm(tmp_adev), false);
5909 
5910 		/* disable ras on ALL IPs */
5911 		if (!need_emergency_restart &&
5912 		      amdgpu_device_ip_need_full_reset(tmp_adev))
5913 			amdgpu_ras_suspend(tmp_adev);
5914 
5915 		for (i = 0; i < AMDGPU_MAX_RINGS; ++i) {
5916 			struct amdgpu_ring *ring = tmp_adev->rings[i];
5917 
5918 			if (!amdgpu_ring_sched_ready(ring))
5919 				continue;
5920 
5921 			drm_sched_stop(&ring->sched, job ? &job->base : NULL);
5922 
5923 			if (need_emergency_restart)
5924 				amdgpu_job_stop_all_jobs_on_sched(&ring->sched);
5925 		}
5926 		atomic_inc(&tmp_adev->gpu_reset_counter);
5927 	}
5928 
5929 	if (need_emergency_restart)
5930 		goto skip_sched_resume;
5931 
5932 	/*
5933 	 * Must check guilty signal here since after this point all old
5934 	 * HW fences are force signaled.
5935 	 *
5936 	 * job->base holds a reference to parent fence
5937 	 */
5938 	if (job && dma_fence_is_signaled(&job->hw_fence)) {
5939 		job_signaled = true;
5940 		dev_info(adev->dev, "Guilty job already signaled, skipping HW reset");
5941 		goto skip_hw_reset;
5942 	}
5943 
5944 retry:	/* Rest of adevs pre asic reset from XGMI hive. */
5945 	list_for_each_entry(tmp_adev, device_list_handle, reset_list) {
5946 		r = amdgpu_device_pre_asic_reset(tmp_adev, reset_context);
5947 		/*TODO Should we stop ?*/
5948 		if (r) {
5949 			dev_err(tmp_adev->dev, "GPU pre asic reset failed with err, %d for drm dev, %s ",
5950 				  r, adev_to_drm(tmp_adev)->unique);
5951 			tmp_adev->asic_reset_res = r;
5952 		}
5953 	}
5954 
5955 	/* Actual ASIC resets if needed.*/
5956 	/* Host driver will handle XGMI hive reset for SRIOV */
5957 	if (amdgpu_sriov_vf(adev)) {
5958 		if (amdgpu_ras_get_fed_status(adev) || amdgpu_virt_rcvd_ras_interrupt(adev)) {
5959 			dev_dbg(adev->dev, "Detected RAS error, wait for FLR completion\n");
5960 			amdgpu_ras_set_fed(adev, true);
5961 			set_bit(AMDGPU_HOST_FLR, &reset_context->flags);
5962 		}
5963 
5964 		r = amdgpu_device_reset_sriov(adev, reset_context);
5965 		if (AMDGPU_RETRY_SRIOV_RESET(r) && (retry_limit--) > 0) {
5966 			amdgpu_virt_release_full_gpu(adev, true);
5967 			goto retry;
5968 		}
5969 		if (r)
5970 			adev->asic_reset_res = r;
5971 	} else {
5972 		r = amdgpu_do_asic_reset(device_list_handle, reset_context);
5973 		if (r && r == -EAGAIN)
5974 			goto retry;
5975 	}
5976 
5977 	list_for_each_entry(tmp_adev, device_list_handle, reset_list) {
5978 		/*
5979 		 * Drop any pending non scheduler resets queued before reset is done.
5980 		 * Any reset scheduled after this point would be valid. Scheduler resets
5981 		 * were already dropped during drm_sched_stop and no new ones can come
5982 		 * in before drm_sched_start.
5983 		 */
5984 		amdgpu_device_stop_pending_resets(tmp_adev);
5985 	}
5986 
5987 skip_hw_reset:
5988 
5989 	/* Post ASIC reset for all devs .*/
5990 	list_for_each_entry(tmp_adev, device_list_handle, reset_list) {
5991 
5992 		for (i = 0; i < AMDGPU_MAX_RINGS; ++i) {
5993 			struct amdgpu_ring *ring = tmp_adev->rings[i];
5994 
5995 			if (!amdgpu_ring_sched_ready(ring))
5996 				continue;
5997 
5998 			drm_sched_start(&ring->sched, 0);
5999 		}
6000 
6001 		if (!drm_drv_uses_atomic_modeset(adev_to_drm(tmp_adev)) && !job_signaled)
6002 			drm_helper_resume_force_mode(adev_to_drm(tmp_adev));
6003 
6004 		if (tmp_adev->asic_reset_res)
6005 			r = tmp_adev->asic_reset_res;
6006 
6007 		tmp_adev->asic_reset_res = 0;
6008 
6009 		if (r) {
6010 			/* bad news, how to tell it to userspace ?
6011 			 * for ras error, we should report GPU bad status instead of
6012 			 * reset failure
6013 			 */
6014 			if (reset_context->src != AMDGPU_RESET_SRC_RAS ||
6015 			    !amdgpu_ras_eeprom_check_err_threshold(tmp_adev))
6016 				dev_info(tmp_adev->dev, "GPU reset(%d) failed\n",
6017 					atomic_read(&tmp_adev->gpu_reset_counter));
6018 			amdgpu_vf_error_put(tmp_adev, AMDGIM_ERROR_VF_GPU_RESET_FAIL, 0, r);
6019 		} else {
6020 			dev_info(tmp_adev->dev, "GPU reset(%d) succeeded!\n", atomic_read(&tmp_adev->gpu_reset_counter));
6021 			if (amdgpu_acpi_smart_shift_update(adev_to_drm(tmp_adev), AMDGPU_SS_DEV_D0))
6022 				DRM_WARN("smart shift update failed\n");
6023 		}
6024 	}
6025 
6026 skip_sched_resume:
6027 	list_for_each_entry(tmp_adev, device_list_handle, reset_list) {
6028 		/* unlock kfd: SRIOV would do it separately */
6029 		if (!need_emergency_restart && !amdgpu_sriov_vf(tmp_adev))
6030 			amdgpu_amdkfd_post_reset(tmp_adev);
6031 
6032 		/* kfd_post_reset will do nothing if kfd device is not initialized,
6033 		 * need to bring up kfd here if it's not be initialized before
6034 		 */
6035 		if (!adev->kfd.init_complete)
6036 			amdgpu_amdkfd_device_init(adev);
6037 
6038 		if (audio_suspended)
6039 			amdgpu_device_resume_display_audio(tmp_adev);
6040 
6041 		amdgpu_device_unset_mp1_state(tmp_adev);
6042 
6043 		amdgpu_ras_set_error_query_ready(tmp_adev, true);
6044 	}
6045 
6046 	tmp_adev = list_first_entry(device_list_handle, struct amdgpu_device,
6047 					    reset_list);
6048 	amdgpu_device_unlock_reset_domain(tmp_adev->reset_domain);
6049 
6050 end_reset:
6051 	if (hive) {
6052 		mutex_unlock(&hive->hive_lock);
6053 		amdgpu_put_xgmi_hive(hive);
6054 	}
6055 
6056 	if (r)
6057 		dev_info(adev->dev, "GPU reset end with ret = %d\n", r);
6058 
6059 	atomic_set(&adev->reset_domain->reset_res, r);
6060 	return r;
6061 }
6062 
6063 /**
6064  * amdgpu_device_partner_bandwidth - find the bandwidth of appropriate partner
6065  *
6066  * @adev: amdgpu_device pointer
6067  * @speed: pointer to the speed of the link
6068  * @width: pointer to the width of the link
6069  *
6070  * Evaluate the hierarchy to find the speed and bandwidth capabilities of the
6071  * first physical partner to an AMD dGPU.
6072  * This will exclude any virtual switches and links.
6073  */
6074 static void amdgpu_device_partner_bandwidth(struct amdgpu_device *adev,
6075 					    enum pci_bus_speed *speed,
6076 					    enum pcie_link_width *width)
6077 {
6078 	struct pci_dev *parent = adev->pdev;
6079 
6080 	if (!speed || !width)
6081 		return;
6082 
6083 	*speed = PCI_SPEED_UNKNOWN;
6084 	*width = PCIE_LNK_WIDTH_UNKNOWN;
6085 
6086 	if (amdgpu_device_pcie_dynamic_switching_supported(adev)) {
6087 		while ((parent = pci_upstream_bridge(parent))) {
6088 			/* skip upstream/downstream switches internal to dGPU*/
6089 			if (parent->vendor == PCI_VENDOR_ID_ATI)
6090 				continue;
6091 			*speed = pcie_get_speed_cap(parent);
6092 			*width = pcie_get_width_cap(parent);
6093 			break;
6094 		}
6095 	} else {
6096 		/* use the current speeds rather than max if switching is not supported */
6097 		pcie_bandwidth_available(adev->pdev, NULL, speed, width);
6098 	}
6099 }
6100 
6101 /**
6102  * amdgpu_device_get_pcie_info - fence pcie info about the PCIE slot
6103  *
6104  * @adev: amdgpu_device pointer
6105  *
6106  * Fetchs and stores in the driver the PCIE capabilities (gen speed
6107  * and lanes) of the slot the device is in. Handles APUs and
6108  * virtualized environments where PCIE config space may not be available.
6109  */
6110 static void amdgpu_device_get_pcie_info(struct amdgpu_device *adev)
6111 {
6112 	struct pci_dev *pdev;
6113 	enum pci_bus_speed speed_cap, platform_speed_cap;
6114 	enum pcie_link_width platform_link_width;
6115 
6116 	if (amdgpu_pcie_gen_cap)
6117 		adev->pm.pcie_gen_mask = amdgpu_pcie_gen_cap;
6118 
6119 	if (amdgpu_pcie_lane_cap)
6120 		adev->pm.pcie_mlw_mask = amdgpu_pcie_lane_cap;
6121 
6122 	/* covers APUs as well */
6123 	if (pci_is_root_bus(adev->pdev->bus) && !amdgpu_passthrough(adev)) {
6124 		if (adev->pm.pcie_gen_mask == 0)
6125 			adev->pm.pcie_gen_mask = AMDGPU_DEFAULT_PCIE_GEN_MASK;
6126 		if (adev->pm.pcie_mlw_mask == 0)
6127 			adev->pm.pcie_mlw_mask = AMDGPU_DEFAULT_PCIE_MLW_MASK;
6128 		return;
6129 	}
6130 
6131 	if (adev->pm.pcie_gen_mask && adev->pm.pcie_mlw_mask)
6132 		return;
6133 
6134 	amdgpu_device_partner_bandwidth(adev, &platform_speed_cap,
6135 					&platform_link_width);
6136 
6137 	if (adev->pm.pcie_gen_mask == 0) {
6138 		/* asic caps */
6139 		pdev = adev->pdev;
6140 		speed_cap = pcie_get_speed_cap(pdev);
6141 		if (speed_cap == PCI_SPEED_UNKNOWN) {
6142 			adev->pm.pcie_gen_mask |= (CAIL_ASIC_PCIE_LINK_SPEED_SUPPORT_GEN1 |
6143 						  CAIL_ASIC_PCIE_LINK_SPEED_SUPPORT_GEN2 |
6144 						  CAIL_ASIC_PCIE_LINK_SPEED_SUPPORT_GEN3);
6145 		} else {
6146 			if (speed_cap == PCIE_SPEED_32_0GT)
6147 				adev->pm.pcie_gen_mask |= (CAIL_ASIC_PCIE_LINK_SPEED_SUPPORT_GEN1 |
6148 							  CAIL_ASIC_PCIE_LINK_SPEED_SUPPORT_GEN2 |
6149 							  CAIL_ASIC_PCIE_LINK_SPEED_SUPPORT_GEN3 |
6150 							  CAIL_ASIC_PCIE_LINK_SPEED_SUPPORT_GEN4 |
6151 							  CAIL_ASIC_PCIE_LINK_SPEED_SUPPORT_GEN5);
6152 			else if (speed_cap == PCIE_SPEED_16_0GT)
6153 				adev->pm.pcie_gen_mask |= (CAIL_ASIC_PCIE_LINK_SPEED_SUPPORT_GEN1 |
6154 							  CAIL_ASIC_PCIE_LINK_SPEED_SUPPORT_GEN2 |
6155 							  CAIL_ASIC_PCIE_LINK_SPEED_SUPPORT_GEN3 |
6156 							  CAIL_ASIC_PCIE_LINK_SPEED_SUPPORT_GEN4);
6157 			else if (speed_cap == PCIE_SPEED_8_0GT)
6158 				adev->pm.pcie_gen_mask |= (CAIL_ASIC_PCIE_LINK_SPEED_SUPPORT_GEN1 |
6159 							  CAIL_ASIC_PCIE_LINK_SPEED_SUPPORT_GEN2 |
6160 							  CAIL_ASIC_PCIE_LINK_SPEED_SUPPORT_GEN3);
6161 			else if (speed_cap == PCIE_SPEED_5_0GT)
6162 				adev->pm.pcie_gen_mask |= (CAIL_ASIC_PCIE_LINK_SPEED_SUPPORT_GEN1 |
6163 							  CAIL_ASIC_PCIE_LINK_SPEED_SUPPORT_GEN2);
6164 			else
6165 				adev->pm.pcie_gen_mask |= CAIL_ASIC_PCIE_LINK_SPEED_SUPPORT_GEN1;
6166 		}
6167 		/* platform caps */
6168 		if (platform_speed_cap == PCI_SPEED_UNKNOWN) {
6169 			adev->pm.pcie_gen_mask |= (CAIL_PCIE_LINK_SPEED_SUPPORT_GEN1 |
6170 						   CAIL_PCIE_LINK_SPEED_SUPPORT_GEN2);
6171 		} else {
6172 			if (platform_speed_cap == PCIE_SPEED_32_0GT)
6173 				adev->pm.pcie_gen_mask |= (CAIL_PCIE_LINK_SPEED_SUPPORT_GEN1 |
6174 							   CAIL_PCIE_LINK_SPEED_SUPPORT_GEN2 |
6175 							   CAIL_PCIE_LINK_SPEED_SUPPORT_GEN3 |
6176 							   CAIL_PCIE_LINK_SPEED_SUPPORT_GEN4 |
6177 							   CAIL_PCIE_LINK_SPEED_SUPPORT_GEN5);
6178 			else if (platform_speed_cap == PCIE_SPEED_16_0GT)
6179 				adev->pm.pcie_gen_mask |= (CAIL_PCIE_LINK_SPEED_SUPPORT_GEN1 |
6180 							   CAIL_PCIE_LINK_SPEED_SUPPORT_GEN2 |
6181 							   CAIL_PCIE_LINK_SPEED_SUPPORT_GEN3 |
6182 							   CAIL_PCIE_LINK_SPEED_SUPPORT_GEN4);
6183 			else if (platform_speed_cap == PCIE_SPEED_8_0GT)
6184 				adev->pm.pcie_gen_mask |= (CAIL_PCIE_LINK_SPEED_SUPPORT_GEN1 |
6185 							   CAIL_PCIE_LINK_SPEED_SUPPORT_GEN2 |
6186 							   CAIL_PCIE_LINK_SPEED_SUPPORT_GEN3);
6187 			else if (platform_speed_cap == PCIE_SPEED_5_0GT)
6188 				adev->pm.pcie_gen_mask |= (CAIL_PCIE_LINK_SPEED_SUPPORT_GEN1 |
6189 							   CAIL_PCIE_LINK_SPEED_SUPPORT_GEN2);
6190 			else
6191 				adev->pm.pcie_gen_mask |= CAIL_PCIE_LINK_SPEED_SUPPORT_GEN1;
6192 
6193 		}
6194 	}
6195 	if (adev->pm.pcie_mlw_mask == 0) {
6196 		if (platform_link_width == PCIE_LNK_WIDTH_UNKNOWN) {
6197 			adev->pm.pcie_mlw_mask |= AMDGPU_DEFAULT_PCIE_MLW_MASK;
6198 		} else {
6199 			switch (platform_link_width) {
6200 			case PCIE_LNK_X32:
6201 				adev->pm.pcie_mlw_mask = (CAIL_PCIE_LINK_WIDTH_SUPPORT_X32 |
6202 							  CAIL_PCIE_LINK_WIDTH_SUPPORT_X16 |
6203 							  CAIL_PCIE_LINK_WIDTH_SUPPORT_X12 |
6204 							  CAIL_PCIE_LINK_WIDTH_SUPPORT_X8 |
6205 							  CAIL_PCIE_LINK_WIDTH_SUPPORT_X4 |
6206 							  CAIL_PCIE_LINK_WIDTH_SUPPORT_X2 |
6207 							  CAIL_PCIE_LINK_WIDTH_SUPPORT_X1);
6208 				break;
6209 			case PCIE_LNK_X16:
6210 				adev->pm.pcie_mlw_mask = (CAIL_PCIE_LINK_WIDTH_SUPPORT_X16 |
6211 							  CAIL_PCIE_LINK_WIDTH_SUPPORT_X12 |
6212 							  CAIL_PCIE_LINK_WIDTH_SUPPORT_X8 |
6213 							  CAIL_PCIE_LINK_WIDTH_SUPPORT_X4 |
6214 							  CAIL_PCIE_LINK_WIDTH_SUPPORT_X2 |
6215 							  CAIL_PCIE_LINK_WIDTH_SUPPORT_X1);
6216 				break;
6217 			case PCIE_LNK_X12:
6218 				adev->pm.pcie_mlw_mask = (CAIL_PCIE_LINK_WIDTH_SUPPORT_X12 |
6219 							  CAIL_PCIE_LINK_WIDTH_SUPPORT_X8 |
6220 							  CAIL_PCIE_LINK_WIDTH_SUPPORT_X4 |
6221 							  CAIL_PCIE_LINK_WIDTH_SUPPORT_X2 |
6222 							  CAIL_PCIE_LINK_WIDTH_SUPPORT_X1);
6223 				break;
6224 			case PCIE_LNK_X8:
6225 				adev->pm.pcie_mlw_mask = (CAIL_PCIE_LINK_WIDTH_SUPPORT_X8 |
6226 							  CAIL_PCIE_LINK_WIDTH_SUPPORT_X4 |
6227 							  CAIL_PCIE_LINK_WIDTH_SUPPORT_X2 |
6228 							  CAIL_PCIE_LINK_WIDTH_SUPPORT_X1);
6229 				break;
6230 			case PCIE_LNK_X4:
6231 				adev->pm.pcie_mlw_mask = (CAIL_PCIE_LINK_WIDTH_SUPPORT_X4 |
6232 							  CAIL_PCIE_LINK_WIDTH_SUPPORT_X2 |
6233 							  CAIL_PCIE_LINK_WIDTH_SUPPORT_X1);
6234 				break;
6235 			case PCIE_LNK_X2:
6236 				adev->pm.pcie_mlw_mask = (CAIL_PCIE_LINK_WIDTH_SUPPORT_X2 |
6237 							  CAIL_PCIE_LINK_WIDTH_SUPPORT_X1);
6238 				break;
6239 			case PCIE_LNK_X1:
6240 				adev->pm.pcie_mlw_mask = CAIL_PCIE_LINK_WIDTH_SUPPORT_X1;
6241 				break;
6242 			default:
6243 				break;
6244 			}
6245 		}
6246 	}
6247 }
6248 
6249 /**
6250  * amdgpu_device_is_peer_accessible - Check peer access through PCIe BAR
6251  *
6252  * @adev: amdgpu_device pointer
6253  * @peer_adev: amdgpu_device pointer for peer device trying to access @adev
6254  *
6255  * Return true if @peer_adev can access (DMA) @adev through the PCIe
6256  * BAR, i.e. @adev is "large BAR" and the BAR matches the DMA mask of
6257  * @peer_adev.
6258  */
6259 bool amdgpu_device_is_peer_accessible(struct amdgpu_device *adev,
6260 				      struct amdgpu_device *peer_adev)
6261 {
6262 #ifdef CONFIG_HSA_AMD_P2P
6263 	bool p2p_access =
6264 		!adev->gmc.xgmi.connected_to_cpu &&
6265 		!(pci_p2pdma_distance(adev->pdev, peer_adev->dev, false) < 0);
6266 	if (!p2p_access)
6267 		dev_info(adev->dev, "PCIe P2P access from peer device %s is not supported by the chipset\n",
6268 			pci_name(peer_adev->pdev));
6269 
6270 	bool is_large_bar = adev->gmc.visible_vram_size &&
6271 		adev->gmc.real_vram_size == adev->gmc.visible_vram_size;
6272 	bool p2p_addressable = amdgpu_device_check_iommu_remap(peer_adev);
6273 
6274 	if (!p2p_addressable) {
6275 		uint64_t address_mask = peer_adev->dev->dma_mask ?
6276 			~*peer_adev->dev->dma_mask : ~((1ULL << 32) - 1);
6277 		resource_size_t aper_limit =
6278 			adev->gmc.aper_base + adev->gmc.aper_size - 1;
6279 
6280 		p2p_addressable = !(adev->gmc.aper_base & address_mask ||
6281 				     aper_limit & address_mask);
6282 	}
6283 	return pcie_p2p && is_large_bar && p2p_access && p2p_addressable;
6284 #else
6285 	return false;
6286 #endif
6287 }
6288 
6289 int amdgpu_device_baco_enter(struct drm_device *dev)
6290 {
6291 	struct amdgpu_device *adev = drm_to_adev(dev);
6292 	struct amdgpu_ras *ras = amdgpu_ras_get_context(adev);
6293 
6294 	if (!amdgpu_device_supports_baco(dev))
6295 		return -ENOTSUPP;
6296 
6297 	if (ras && adev->ras_enabled &&
6298 	    adev->nbio.funcs->enable_doorbell_interrupt)
6299 		adev->nbio.funcs->enable_doorbell_interrupt(adev, false);
6300 
6301 	return amdgpu_dpm_baco_enter(adev);
6302 }
6303 
6304 int amdgpu_device_baco_exit(struct drm_device *dev)
6305 {
6306 	struct amdgpu_device *adev = drm_to_adev(dev);
6307 	struct amdgpu_ras *ras = amdgpu_ras_get_context(adev);
6308 	int ret = 0;
6309 
6310 	if (!amdgpu_device_supports_baco(dev))
6311 		return -ENOTSUPP;
6312 
6313 	ret = amdgpu_dpm_baco_exit(adev);
6314 	if (ret)
6315 		return ret;
6316 
6317 	if (ras && adev->ras_enabled &&
6318 	    adev->nbio.funcs->enable_doorbell_interrupt)
6319 		adev->nbio.funcs->enable_doorbell_interrupt(adev, true);
6320 
6321 	if (amdgpu_passthrough(adev) && adev->nbio.funcs &&
6322 	    adev->nbio.funcs->clear_doorbell_interrupt)
6323 		adev->nbio.funcs->clear_doorbell_interrupt(adev);
6324 
6325 	return 0;
6326 }
6327 
6328 /**
6329  * amdgpu_pci_error_detected - Called when a PCI error is detected.
6330  * @pdev: PCI device struct
6331  * @state: PCI channel state
6332  *
6333  * Description: Called when a PCI error is detected.
6334  *
6335  * Return: PCI_ERS_RESULT_NEED_RESET or PCI_ERS_RESULT_DISCONNECT.
6336  */
6337 pci_ers_result_t amdgpu_pci_error_detected(struct pci_dev *pdev, pci_channel_state_t state)
6338 {
6339 	struct drm_device *dev = pci_get_drvdata(pdev);
6340 	struct amdgpu_device *adev = drm_to_adev(dev);
6341 	int i;
6342 
6343 	DRM_INFO("PCI error: detected callback, state(%d)!!\n", state);
6344 
6345 	if (adev->gmc.xgmi.num_physical_nodes > 1) {
6346 		DRM_WARN("No support for XGMI hive yet...");
6347 		return PCI_ERS_RESULT_DISCONNECT;
6348 	}
6349 
6350 	adev->pci_channel_state = state;
6351 
6352 	switch (state) {
6353 	case pci_channel_io_normal:
6354 		return PCI_ERS_RESULT_CAN_RECOVER;
6355 	/* Fatal error, prepare for slot reset */
6356 	case pci_channel_io_frozen:
6357 		/*
6358 		 * Locking adev->reset_domain->sem will prevent any external access
6359 		 * to GPU during PCI error recovery
6360 		 */
6361 		amdgpu_device_lock_reset_domain(adev->reset_domain);
6362 		amdgpu_device_set_mp1_state(adev);
6363 
6364 		/*
6365 		 * Block any work scheduling as we do for regular GPU reset
6366 		 * for the duration of the recovery
6367 		 */
6368 		for (i = 0; i < AMDGPU_MAX_RINGS; ++i) {
6369 			struct amdgpu_ring *ring = adev->rings[i];
6370 
6371 			if (!amdgpu_ring_sched_ready(ring))
6372 				continue;
6373 
6374 			drm_sched_stop(&ring->sched, NULL);
6375 		}
6376 		atomic_inc(&adev->gpu_reset_counter);
6377 		return PCI_ERS_RESULT_NEED_RESET;
6378 	case pci_channel_io_perm_failure:
6379 		/* Permanent error, prepare for device removal */
6380 		return PCI_ERS_RESULT_DISCONNECT;
6381 	}
6382 
6383 	return PCI_ERS_RESULT_NEED_RESET;
6384 }
6385 
6386 /**
6387  * amdgpu_pci_mmio_enabled - Enable MMIO and dump debug registers
6388  * @pdev: pointer to PCI device
6389  */
6390 pci_ers_result_t amdgpu_pci_mmio_enabled(struct pci_dev *pdev)
6391 {
6392 
6393 	DRM_INFO("PCI error: mmio enabled callback!!\n");
6394 
6395 	/* TODO - dump whatever for debugging purposes */
6396 
6397 	/* This called only if amdgpu_pci_error_detected returns
6398 	 * PCI_ERS_RESULT_CAN_RECOVER. Read/write to the device still
6399 	 * works, no need to reset slot.
6400 	 */
6401 
6402 	return PCI_ERS_RESULT_RECOVERED;
6403 }
6404 
6405 /**
6406  * amdgpu_pci_slot_reset - Called when PCI slot has been reset.
6407  * @pdev: PCI device struct
6408  *
6409  * Description: This routine is called by the pci error recovery
6410  * code after the PCI slot has been reset, just before we
6411  * should resume normal operations.
6412  */
6413 pci_ers_result_t amdgpu_pci_slot_reset(struct pci_dev *pdev)
6414 {
6415 	struct drm_device *dev = pci_get_drvdata(pdev);
6416 	struct amdgpu_device *adev = drm_to_adev(dev);
6417 	int r, i;
6418 	struct amdgpu_reset_context reset_context;
6419 	u32 memsize;
6420 	struct list_head device_list;
6421 
6422 	/* PCI error slot reset should be skipped During RAS recovery */
6423 	if ((amdgpu_ip_version(adev, GC_HWIP, 0) == IP_VERSION(9, 4, 3) ||
6424 	    amdgpu_ip_version(adev, GC_HWIP, 0) == IP_VERSION(9, 4, 4)) &&
6425 	    amdgpu_ras_in_recovery(adev))
6426 		return PCI_ERS_RESULT_RECOVERED;
6427 
6428 	DRM_INFO("PCI error: slot reset callback!!\n");
6429 
6430 	memset(&reset_context, 0, sizeof(reset_context));
6431 
6432 	INIT_LIST_HEAD(&device_list);
6433 	list_add_tail(&adev->reset_list, &device_list);
6434 
6435 	/* wait for asic to come out of reset */
6436 	msleep(500);
6437 
6438 	/* Restore PCI confspace */
6439 	amdgpu_device_load_pci_state(pdev);
6440 
6441 	/* confirm  ASIC came out of reset */
6442 	for (i = 0; i < adev->usec_timeout; i++) {
6443 		memsize = amdgpu_asic_get_config_memsize(adev);
6444 
6445 		if (memsize != 0xffffffff)
6446 			break;
6447 		udelay(1);
6448 	}
6449 	if (memsize == 0xffffffff) {
6450 		r = -ETIME;
6451 		goto out;
6452 	}
6453 
6454 	reset_context.method = AMD_RESET_METHOD_NONE;
6455 	reset_context.reset_req_dev = adev;
6456 	set_bit(AMDGPU_NEED_FULL_RESET, &reset_context.flags);
6457 	set_bit(AMDGPU_SKIP_HW_RESET, &reset_context.flags);
6458 
6459 	adev->no_hw_access = true;
6460 	r = amdgpu_device_pre_asic_reset(adev, &reset_context);
6461 	adev->no_hw_access = false;
6462 	if (r)
6463 		goto out;
6464 
6465 	r = amdgpu_do_asic_reset(&device_list, &reset_context);
6466 
6467 out:
6468 	if (!r) {
6469 		if (amdgpu_device_cache_pci_state(adev->pdev))
6470 			pci_restore_state(adev->pdev);
6471 
6472 		DRM_INFO("PCIe error recovery succeeded\n");
6473 	} else {
6474 		DRM_ERROR("PCIe error recovery failed, err:%d", r);
6475 		amdgpu_device_unset_mp1_state(adev);
6476 		amdgpu_device_unlock_reset_domain(adev->reset_domain);
6477 	}
6478 
6479 	return r ? PCI_ERS_RESULT_DISCONNECT : PCI_ERS_RESULT_RECOVERED;
6480 }
6481 
6482 /**
6483  * amdgpu_pci_resume() - resume normal ops after PCI reset
6484  * @pdev: pointer to PCI device
6485  *
6486  * Called when the error recovery driver tells us that its
6487  * OK to resume normal operation.
6488  */
6489 void amdgpu_pci_resume(struct pci_dev *pdev)
6490 {
6491 	struct drm_device *dev = pci_get_drvdata(pdev);
6492 	struct amdgpu_device *adev = drm_to_adev(dev);
6493 	int i;
6494 
6495 
6496 	DRM_INFO("PCI error: resume callback!!\n");
6497 
6498 	/* Only continue execution for the case of pci_channel_io_frozen */
6499 	if (adev->pci_channel_state != pci_channel_io_frozen)
6500 		return;
6501 
6502 	for (i = 0; i < AMDGPU_MAX_RINGS; ++i) {
6503 		struct amdgpu_ring *ring = adev->rings[i];
6504 
6505 		if (!amdgpu_ring_sched_ready(ring))
6506 			continue;
6507 
6508 		drm_sched_start(&ring->sched, 0);
6509 	}
6510 
6511 	amdgpu_device_unset_mp1_state(adev);
6512 	amdgpu_device_unlock_reset_domain(adev->reset_domain);
6513 }
6514 
6515 bool amdgpu_device_cache_pci_state(struct pci_dev *pdev)
6516 {
6517 	struct drm_device *dev = pci_get_drvdata(pdev);
6518 	struct amdgpu_device *adev = drm_to_adev(dev);
6519 	int r;
6520 
6521 	if (amdgpu_sriov_vf(adev))
6522 		return false;
6523 
6524 	r = pci_save_state(pdev);
6525 	if (!r) {
6526 		kfree(adev->pci_state);
6527 
6528 		adev->pci_state = pci_store_saved_state(pdev);
6529 
6530 		if (!adev->pci_state) {
6531 			DRM_ERROR("Failed to store PCI saved state");
6532 			return false;
6533 		}
6534 	} else {
6535 		DRM_WARN("Failed to save PCI state, err:%d\n", r);
6536 		return false;
6537 	}
6538 
6539 	return true;
6540 }
6541 
6542 bool amdgpu_device_load_pci_state(struct pci_dev *pdev)
6543 {
6544 	struct drm_device *dev = pci_get_drvdata(pdev);
6545 	struct amdgpu_device *adev = drm_to_adev(dev);
6546 	int r;
6547 
6548 	if (!adev->pci_state)
6549 		return false;
6550 
6551 	r = pci_load_saved_state(pdev, adev->pci_state);
6552 
6553 	if (!r) {
6554 		pci_restore_state(pdev);
6555 	} else {
6556 		DRM_WARN("Failed to load PCI state, err:%d\n", r);
6557 		return false;
6558 	}
6559 
6560 	return true;
6561 }
6562 
6563 void amdgpu_device_flush_hdp(struct amdgpu_device *adev,
6564 		struct amdgpu_ring *ring)
6565 {
6566 #ifdef CONFIG_X86_64
6567 	if ((adev->flags & AMD_IS_APU) && !amdgpu_passthrough(adev))
6568 		return;
6569 #endif
6570 	if (adev->gmc.xgmi.connected_to_cpu)
6571 		return;
6572 
6573 	if (ring && ring->funcs->emit_hdp_flush)
6574 		amdgpu_ring_emit_hdp_flush(ring);
6575 	else
6576 		amdgpu_asic_flush_hdp(adev, ring);
6577 }
6578 
6579 void amdgpu_device_invalidate_hdp(struct amdgpu_device *adev,
6580 		struct amdgpu_ring *ring)
6581 {
6582 #ifdef CONFIG_X86_64
6583 	if ((adev->flags & AMD_IS_APU) && !amdgpu_passthrough(adev))
6584 		return;
6585 #endif
6586 	if (adev->gmc.xgmi.connected_to_cpu)
6587 		return;
6588 
6589 	amdgpu_asic_invalidate_hdp(adev, ring);
6590 }
6591 
6592 int amdgpu_in_reset(struct amdgpu_device *adev)
6593 {
6594 	return atomic_read(&adev->reset_domain->in_gpu_reset);
6595 }
6596 
6597 /**
6598  * amdgpu_device_halt() - bring hardware to some kind of halt state
6599  *
6600  * @adev: amdgpu_device pointer
6601  *
6602  * Bring hardware to some kind of halt state so that no one can touch it
6603  * any more. It will help to maintain error context when error occurred.
6604  * Compare to a simple hang, the system will keep stable at least for SSH
6605  * access. Then it should be trivial to inspect the hardware state and
6606  * see what's going on. Implemented as following:
6607  *
6608  * 1. drm_dev_unplug() makes device inaccessible to user space(IOCTLs, etc),
6609  *    clears all CPU mappings to device, disallows remappings through page faults
6610  * 2. amdgpu_irq_disable_all() disables all interrupts
6611  * 3. amdgpu_fence_driver_hw_fini() signals all HW fences
6612  * 4. set adev->no_hw_access to avoid potential crashes after setp 5
6613  * 5. amdgpu_device_unmap_mmio() clears all MMIO mappings
6614  * 6. pci_disable_device() and pci_wait_for_pending_transaction()
6615  *    flush any in flight DMA operations
6616  */
6617 void amdgpu_device_halt(struct amdgpu_device *adev)
6618 {
6619 	struct pci_dev *pdev = adev->pdev;
6620 	struct drm_device *ddev = adev_to_drm(adev);
6621 
6622 	amdgpu_xcp_dev_unplug(adev);
6623 	drm_dev_unplug(ddev);
6624 
6625 	amdgpu_irq_disable_all(adev);
6626 
6627 	amdgpu_fence_driver_hw_fini(adev);
6628 
6629 	adev->no_hw_access = true;
6630 
6631 	amdgpu_device_unmap_mmio(adev);
6632 
6633 	pci_disable_device(pdev);
6634 	pci_wait_for_pending_transaction(pdev);
6635 }
6636 
6637 u32 amdgpu_device_pcie_port_rreg(struct amdgpu_device *adev,
6638 				u32 reg)
6639 {
6640 	unsigned long flags, address, data;
6641 	u32 r;
6642 
6643 	address = adev->nbio.funcs->get_pcie_port_index_offset(adev);
6644 	data = adev->nbio.funcs->get_pcie_port_data_offset(adev);
6645 
6646 	spin_lock_irqsave(&adev->pcie_idx_lock, flags);
6647 	WREG32(address, reg * 4);
6648 	(void)RREG32(address);
6649 	r = RREG32(data);
6650 	spin_unlock_irqrestore(&adev->pcie_idx_lock, flags);
6651 	return r;
6652 }
6653 
6654 void amdgpu_device_pcie_port_wreg(struct amdgpu_device *adev,
6655 				u32 reg, u32 v)
6656 {
6657 	unsigned long flags, address, data;
6658 
6659 	address = adev->nbio.funcs->get_pcie_port_index_offset(adev);
6660 	data = adev->nbio.funcs->get_pcie_port_data_offset(adev);
6661 
6662 	spin_lock_irqsave(&adev->pcie_idx_lock, flags);
6663 	WREG32(address, reg * 4);
6664 	(void)RREG32(address);
6665 	WREG32(data, v);
6666 	(void)RREG32(data);
6667 	spin_unlock_irqrestore(&adev->pcie_idx_lock, flags);
6668 }
6669 
6670 /**
6671  * amdgpu_device_get_gang - return a reference to the current gang
6672  * @adev: amdgpu_device pointer
6673  *
6674  * Returns: A new reference to the current gang leader.
6675  */
6676 struct dma_fence *amdgpu_device_get_gang(struct amdgpu_device *adev)
6677 {
6678 	struct dma_fence *fence;
6679 
6680 	rcu_read_lock();
6681 	fence = dma_fence_get_rcu_safe(&adev->gang_submit);
6682 	rcu_read_unlock();
6683 	return fence;
6684 }
6685 
6686 /**
6687  * amdgpu_device_switch_gang - switch to a new gang
6688  * @adev: amdgpu_device pointer
6689  * @gang: the gang to switch to
6690  *
6691  * Try to switch to a new gang.
6692  * Returns: NULL if we switched to the new gang or a reference to the current
6693  * gang leader.
6694  */
6695 struct dma_fence *amdgpu_device_switch_gang(struct amdgpu_device *adev,
6696 					    struct dma_fence *gang)
6697 {
6698 	struct dma_fence *old = NULL;
6699 
6700 	do {
6701 		dma_fence_put(old);
6702 		old = amdgpu_device_get_gang(adev);
6703 		if (old == gang)
6704 			break;
6705 
6706 		if (!dma_fence_is_signaled(old))
6707 			return old;
6708 
6709 	} while (cmpxchg((struct dma_fence __force **)&adev->gang_submit,
6710 			 old, gang) != old);
6711 
6712 	dma_fence_put(old);
6713 	return NULL;
6714 }
6715 
6716 bool amdgpu_device_has_display_hardware(struct amdgpu_device *adev)
6717 {
6718 	switch (adev->asic_type) {
6719 #ifdef CONFIG_DRM_AMDGPU_SI
6720 	case CHIP_HAINAN:
6721 #endif
6722 	case CHIP_TOPAZ:
6723 		/* chips with no display hardware */
6724 		return false;
6725 #ifdef CONFIG_DRM_AMDGPU_SI
6726 	case CHIP_TAHITI:
6727 	case CHIP_PITCAIRN:
6728 	case CHIP_VERDE:
6729 	case CHIP_OLAND:
6730 #endif
6731 #ifdef CONFIG_DRM_AMDGPU_CIK
6732 	case CHIP_BONAIRE:
6733 	case CHIP_HAWAII:
6734 	case CHIP_KAVERI:
6735 	case CHIP_KABINI:
6736 	case CHIP_MULLINS:
6737 #endif
6738 	case CHIP_TONGA:
6739 	case CHIP_FIJI:
6740 	case CHIP_POLARIS10:
6741 	case CHIP_POLARIS11:
6742 	case CHIP_POLARIS12:
6743 	case CHIP_VEGAM:
6744 	case CHIP_CARRIZO:
6745 	case CHIP_STONEY:
6746 		/* chips with display hardware */
6747 		return true;
6748 	default:
6749 		/* IP discovery */
6750 		if (!amdgpu_ip_version(adev, DCE_HWIP, 0) ||
6751 		    (adev->harvest_ip_mask & AMD_HARVEST_IP_DMU_MASK))
6752 			return false;
6753 		return true;
6754 	}
6755 }
6756 
6757 uint32_t amdgpu_device_wait_on_rreg(struct amdgpu_device *adev,
6758 		uint32_t inst, uint32_t reg_addr, char reg_name[],
6759 		uint32_t expected_value, uint32_t mask)
6760 {
6761 	uint32_t ret = 0;
6762 	uint32_t old_ = 0;
6763 	uint32_t tmp_ = RREG32(reg_addr);
6764 	uint32_t loop = adev->usec_timeout;
6765 
6766 	while ((tmp_ & (mask)) != (expected_value)) {
6767 		if (old_ != tmp_) {
6768 			loop = adev->usec_timeout;
6769 			old_ = tmp_;
6770 		} else
6771 			udelay(1);
6772 		tmp_ = RREG32(reg_addr);
6773 		loop--;
6774 		if (!loop) {
6775 			DRM_WARN("Register(%d) [%s] failed to reach value 0x%08x != 0x%08xn",
6776 				  inst, reg_name, (uint32_t)expected_value,
6777 				  (uint32_t)(tmp_ & (mask)));
6778 			ret = -ETIMEDOUT;
6779 			break;
6780 		}
6781 	}
6782 	return ret;
6783 }
6784 
6785 ssize_t amdgpu_get_soft_full_reset_mask(struct amdgpu_ring *ring)
6786 {
6787 	ssize_t size = 0;
6788 
6789 	if (!ring || !ring->adev)
6790 		return size;
6791 
6792 	if (amdgpu_device_should_recover_gpu(ring->adev))
6793 		size |= AMDGPU_RESET_TYPE_FULL;
6794 
6795 	if (unlikely(!ring->adev->debug_disable_soft_recovery) &&
6796 	    !amdgpu_sriov_vf(ring->adev) && ring->funcs->soft_recovery)
6797 		size |= AMDGPU_RESET_TYPE_SOFT_RESET;
6798 
6799 	return size;
6800 }
6801 
6802 ssize_t amdgpu_show_reset_mask(char *buf, uint32_t supported_reset)
6803 {
6804 	ssize_t size = 0;
6805 
6806 	if (supported_reset == 0) {
6807 		size += sysfs_emit_at(buf, size, "unsupported");
6808 		size += sysfs_emit_at(buf, size, "\n");
6809 		return size;
6810 
6811 	}
6812 
6813 	if (supported_reset & AMDGPU_RESET_TYPE_SOFT_RESET)
6814 		size += sysfs_emit_at(buf, size, "soft ");
6815 
6816 	if (supported_reset & AMDGPU_RESET_TYPE_PER_QUEUE)
6817 		size += sysfs_emit_at(buf, size, "queue ");
6818 
6819 	if (supported_reset & AMDGPU_RESET_TYPE_PER_PIPE)
6820 		size += sysfs_emit_at(buf, size, "pipe ");
6821 
6822 	if (supported_reset & AMDGPU_RESET_TYPE_FULL)
6823 		size += sysfs_emit_at(buf, size, "full ");
6824 
6825 	size += sysfs_emit_at(buf, size, "\n");
6826 	return size;
6827 }
6828