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