diff options
author | Rex Zhu <Rex.Zhu@amd.com> | 2018-10-09 01:55:49 -0400 |
---|---|---|
committer | Alex Deucher <alexander.deucher@amd.com> | 2018-10-10 15:48:52 -0400 |
commit | c8963ea4ce1783034e1f9cf0d702fa490eb77836 (patch) | |
tree | 09cafe09785721ceba14450917a6461daeb5e5bf /drivers/gpu/drm/amd/amdgpu/amdgpu_ucode.c | |
parent | a2d31dc3cfab29f79c1cda2876d32b909ae26e25 (diff) |
drm/amdgpu: Split amdgpu_ucode_init/fini_bo into two functions
1. one is for create/free bo when init/fini
2. one is for fill the bo before fw loading
the ucode bo only need to be created when load driver
and free when driver unload.
when resume/reset, driver only need to re-fill the bo
if the bo is allocated in vram.
Suggested by Christian.
v2: Return error when bo create failed.
Reviewed-by: Alex Deucher <alexander.deucher@amd.com>
Signed-off-by: Rex Zhu <Rex.Zhu@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
Diffstat (limited to 'drivers/gpu/drm/amd/amdgpu/amdgpu_ucode.c')
-rw-r--r-- | drivers/gpu/drm/amd/amdgpu/amdgpu_ucode.c | 58 |
1 files changed, 29 insertions, 29 deletions
diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_ucode.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_ucode.c index adfeb93c612e..57ed38422089 100644 --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_ucode.c +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_ucode.c | |||
@@ -422,32 +422,42 @@ static int amdgpu_ucode_patch_jt(struct amdgpu_firmware_info *ucode, | |||
422 | return 0; | 422 | return 0; |
423 | } | 423 | } |
424 | 424 | ||
425 | int amdgpu_ucode_create_bo(struct amdgpu_device *adev) | ||
426 | { | ||
427 | if (adev->firmware.load_type != AMDGPU_FW_LOAD_DIRECT) { | ||
428 | amdgpu_bo_create_kernel(adev, adev->firmware.fw_size, PAGE_SIZE, | ||
429 | amdgpu_sriov_vf(adev) ? AMDGPU_GEM_DOMAIN_VRAM : AMDGPU_GEM_DOMAIN_GTT, | ||
430 | &adev->firmware.fw_buf, | ||
431 | &adev->firmware.fw_buf_mc, | ||
432 | &adev->firmware.fw_buf_ptr); | ||
433 | if (!adev->firmware.fw_buf) { | ||
434 | dev_err(adev->dev, "failed to create kernel buffer for firmware.fw_buf\n"); | ||
435 | return -ENOMEM; | ||
436 | } else if (amdgpu_sriov_vf(adev)) { | ||
437 | memset(adev->firmware.fw_buf_ptr, 0, adev->firmware.fw_size); | ||
438 | } | ||
439 | } | ||
440 | return 0; | ||
441 | } | ||
442 | |||
443 | void amdgpu_ucode_free_bo(struct amdgpu_device *adev) | ||
444 | { | ||
445 | if (adev->firmware.load_type != AMDGPU_FW_LOAD_DIRECT) | ||
446 | amdgpu_bo_free_kernel(&adev->firmware.fw_buf, | ||
447 | &adev->firmware.fw_buf_mc, | ||
448 | &adev->firmware.fw_buf_ptr); | ||
449 | } | ||
450 | |||
425 | int amdgpu_ucode_init_bo(struct amdgpu_device *adev) | 451 | int amdgpu_ucode_init_bo(struct amdgpu_device *adev) |
426 | { | 452 | { |
427 | uint64_t fw_offset = 0; | 453 | uint64_t fw_offset = 0; |
428 | int i, err; | 454 | int i; |
429 | struct amdgpu_firmware_info *ucode = NULL; | 455 | struct amdgpu_firmware_info *ucode = NULL; |
430 | const struct common_firmware_header *header = NULL; | 456 | const struct common_firmware_header *header = NULL; |
431 | 457 | ||
432 | if (!adev->firmware.fw_size) { | 458 | /* for baremetal, the ucode is allocated in gtt, so don't need to fill the bo when reset/suspend */ |
433 | dev_warn(adev->dev, "No ip firmware need to load\n"); | 459 | if (!amdgpu_sriov_vf(adev) && (adev->in_gpu_reset || adev->in_suspend)) |
434 | return 0; | 460 | return 0; |
435 | } | ||
436 | |||
437 | if (!adev->in_gpu_reset && !adev->in_suspend) { | ||
438 | err = amdgpu_bo_create_kernel(adev, adev->firmware.fw_size, PAGE_SIZE, | ||
439 | amdgpu_sriov_vf(adev) ? AMDGPU_GEM_DOMAIN_VRAM : AMDGPU_GEM_DOMAIN_GTT, | ||
440 | &adev->firmware.fw_buf, | ||
441 | &adev->firmware.fw_buf_mc, | ||
442 | &adev->firmware.fw_buf_ptr); | ||
443 | if (err) { | ||
444 | dev_err(adev->dev, "failed to create kernel buffer for firmware.fw_buf\n"); | ||
445 | goto failed; | ||
446 | } | ||
447 | } | ||
448 | |||
449 | memset(adev->firmware.fw_buf_ptr, 0, adev->firmware.fw_size); | ||
450 | |||
451 | /* | 461 | /* |
452 | * if SMU loaded firmware, it needn't add SMC, UVD, and VCE | 462 | * if SMU loaded firmware, it needn't add SMC, UVD, and VCE |
453 | * ucode info here | 463 | * ucode info here |
@@ -479,12 +489,6 @@ int amdgpu_ucode_init_bo(struct amdgpu_device *adev) | |||
479 | } | 489 | } |
480 | } | 490 | } |
481 | return 0; | 491 | return 0; |
482 | |||
483 | failed: | ||
484 | if (err) | ||
485 | adev->firmware.load_type = AMDGPU_FW_LOAD_DIRECT; | ||
486 | |||
487 | return err; | ||
488 | } | 492 | } |
489 | 493 | ||
490 | int amdgpu_ucode_fini_bo(struct amdgpu_device *adev) | 494 | int amdgpu_ucode_fini_bo(struct amdgpu_device *adev) |
@@ -503,9 +507,5 @@ int amdgpu_ucode_fini_bo(struct amdgpu_device *adev) | |||
503 | } | 507 | } |
504 | } | 508 | } |
505 | 509 | ||
506 | amdgpu_bo_free_kernel(&adev->firmware.fw_buf, | ||
507 | &adev->firmware.fw_buf_mc, | ||
508 | &adev->firmware.fw_buf_ptr); | ||
509 | |||
510 | return 0; | 510 | return 0; |
511 | } | 511 | } |