diff options
Diffstat (limited to 'drivers/gpu/drm/amd/amdgpu')
| -rw-r--r-- | drivers/gpu/drm/amd/amdgpu/amdgpu_acpi.c | 5 | ||||
| -rw-r--r-- | drivers/gpu/drm/amd/amdgpu/amdgpu_device.c | 8 | ||||
| -rw-r--r-- | drivers/gpu/drm/amd/amdgpu/amdgpu_drv.c | 7 | ||||
| -rw-r--r-- | drivers/gpu/drm/amd/amdgpu/amdgpu_res_cursor.h | 3 | ||||
| -rw-r--r-- | drivers/gpu/drm/amd/amdgpu/gfx_v9_0.c | 21 | ||||
| -rw-r--r-- | drivers/gpu/drm/amd/amdgpu/psp_v12_0.c | 7 | 
6 files changed, 37 insertions, 14 deletions
| diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_acpi.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_acpi.c index 84a1b4bc9bb4..4137e848f6a2 100644 --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_acpi.c +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_acpi.c @@ -26,6 +26,7 @@  #include <linux/slab.h>  #include <linux/power_supply.h>  #include <linux/pm_runtime.h> +#include <linux/suspend.h>  #include <acpi/video.h>  #include <acpi/actbl.h> @@ -1039,10 +1040,10 @@ void amdgpu_acpi_detect(void)   */  bool amdgpu_acpi_is_s0ix_supported(struct amdgpu_device *adev)  { -#if defined(CONFIG_AMD_PMC) || defined(CONFIG_AMD_PMC_MODULE) +#if IS_ENABLED(CONFIG_AMD_PMC) && IS_ENABLED(CONFIG_PM_SLEEP)  	if (acpi_gbl_FADT.flags & ACPI_FADT_LOW_POWER_S0) {  		if (adev->flags & AMD_IS_APU) -			return true; +			return pm_suspend_target_state == PM_SUSPEND_TO_IDLE;  	}  #endif  	return false; diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_device.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_device.c index d303e88e3c23..f3fd5ec710b6 100644 --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_device.c +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_device.c @@ -3504,13 +3504,13 @@ int amdgpu_device_init(struct amdgpu_device *adev,  	r = amdgpu_device_get_job_timeout_settings(adev);  	if (r) {  		dev_err(adev->dev, "invalid lockup_timeout parameter syntax\n"); -		goto failed_unmap; +		return r;  	}  	/* early init functions */  	r = amdgpu_device_ip_early_init(adev);  	if (r) -		goto failed_unmap; +		return r;  	/* doorbell bar mapping and doorbell index init*/  	amdgpu_device_doorbell_init(adev); @@ -3736,10 +3736,6 @@ release_ras_con:  failed:  	amdgpu_vf_error_trans_all(adev); -failed_unmap: -	iounmap(adev->rmmio); -	adev->rmmio = NULL; -  	return r;  } diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_drv.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_drv.c index 361b86b71b56..5ed8381ae0f5 100644 --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_drv.c +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_drv.c @@ -1213,6 +1213,13 @@ static const struct pci_device_id pciidlist[] = {  	{0x1002, 0x740F, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CHIP_ALDEBARAN|AMD_EXP_HW_SUPPORT},  	{0x1002, 0x7410, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CHIP_ALDEBARAN|AMD_EXP_HW_SUPPORT}, +	/* BEIGE_GOBY */ +	{0x1002, 0x7420, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CHIP_BEIGE_GOBY}, +	{0x1002, 0x7421, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CHIP_BEIGE_GOBY}, +	{0x1002, 0x7422, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CHIP_BEIGE_GOBY}, +	{0x1002, 0x7423, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CHIP_BEIGE_GOBY}, +	{0x1002, 0x743F, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CHIP_BEIGE_GOBY}, +  	{0, 0, 0}  }; diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_res_cursor.h b/drivers/gpu/drm/amd/amdgpu/amdgpu_res_cursor.h index 59e0fefb15aa..acfa207cf970 100644 --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_res_cursor.h +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_res_cursor.h @@ -54,11 +54,12 @@ static inline void amdgpu_res_first(struct ttm_resource *res,  {  	struct drm_mm_node *node; -	if (!res) { +	if (!res || res->mem_type == TTM_PL_SYSTEM) {  		cur->start = start;  		cur->size = size;  		cur->remaining = size;  		cur->node = NULL; +		WARN_ON(res && start + size > res->num_pages << PAGE_SHIFT);  		return;  	} diff --git a/drivers/gpu/drm/amd/amdgpu/gfx_v9_0.c b/drivers/gpu/drm/amd/amdgpu/gfx_v9_0.c index 044076ec1d03..6a23c6826e12 100644 --- a/drivers/gpu/drm/amd/amdgpu/gfx_v9_0.c +++ b/drivers/gpu/drm/amd/amdgpu/gfx_v9_0.c @@ -1295,6 +1295,16 @@ static bool is_raven_kicker(struct amdgpu_device *adev)  		return false;  } +static bool check_if_enlarge_doorbell_range(struct amdgpu_device *adev) +{ +	if ((adev->asic_type == CHIP_RENOIR) && +	    (adev->gfx.me_fw_version >= 0x000000a5) && +	    (adev->gfx.me_feature_version >= 52)) +		return true; +	else +		return false; +} +  static void gfx_v9_0_check_if_need_gfxoff(struct amdgpu_device *adev)  {  	if (gfx_v9_0_should_disable_gfxoff(adev->pdev)) @@ -3675,7 +3685,16 @@ static int gfx_v9_0_kiq_init_register(struct amdgpu_ring *ring)  	if (ring->use_doorbell) {  		WREG32_SOC15(GC, 0, mmCP_MEC_DOORBELL_RANGE_LOWER,  					(adev->doorbell_index.kiq * 2) << 2); -		WREG32_SOC15(GC, 0, mmCP_MEC_DOORBELL_RANGE_UPPER, +		/* If GC has entered CGPG, ringing doorbell > first page +		 * doesn't wakeup GC. Enlarge CP_MEC_DOORBELL_RANGE_UPPER to +		 * workaround this issue. And this change has to align with firmware +		 * update. +		 */ +		if (check_if_enlarge_doorbell_range(adev)) +			WREG32_SOC15(GC, 0, mmCP_MEC_DOORBELL_RANGE_UPPER, +					(adev->doorbell.size - 4)); +		else +			WREG32_SOC15(GC, 0, mmCP_MEC_DOORBELL_RANGE_UPPER,  					(adev->doorbell_index.userqueue_end * 2) << 2);  	} diff --git a/drivers/gpu/drm/amd/amdgpu/psp_v12_0.c b/drivers/gpu/drm/amd/amdgpu/psp_v12_0.c index 618e5b6b85d9..536d41f327c1 100644 --- a/drivers/gpu/drm/amd/amdgpu/psp_v12_0.c +++ b/drivers/gpu/drm/amd/amdgpu/psp_v12_0.c @@ -67,7 +67,7 @@ static int psp_v12_0_init_microcode(struct psp_context *psp)  	err = psp_init_asd_microcode(psp, chip_name);  	if (err) -		goto out; +		return err;  	snprintf(fw_name, sizeof(fw_name), "amdgpu/%s_ta.bin", chip_name);  	err = request_firmware(&adev->psp.ta_fw, fw_name, adev->dev); @@ -80,7 +80,7 @@ static int psp_v12_0_init_microcode(struct psp_context *psp)  	} else {  		err = amdgpu_ucode_validate(adev->psp.ta_fw);  		if (err) -			goto out2; +			goto out;  		ta_hdr = (const struct ta_firmware_header_v1_0 *)  				 adev->psp.ta_fw->data; @@ -105,10 +105,9 @@ static int psp_v12_0_init_microcode(struct psp_context *psp)  	return 0; -out2: +out:  	release_firmware(adev->psp.ta_fw);  	adev->psp.ta_fw = NULL; -out:  	if (err) {  		dev_err(adev->dev,  			"psp v12.0: Failed to load firmware \"%s\"\n", | 
