drm/radeon: add support for loading new UVD fw
Signed-off-by: Christian König <christian.koenig@amd.com> Signed-off-by: Arindam Nath <arindam.nath@amd.com> Reviewed-by: Leo Liu <leo.liu@amd.com> Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
This commit is contained in:
parent
794f50b95d
commit
7050c6ef5f
@ -1679,6 +1679,7 @@ int radeon_pm_get_type_index(struct radeon_device *rdev,
|
|||||||
#define RADEON_UVD_HEAP_SIZE (1024*1024)
|
#define RADEON_UVD_HEAP_SIZE (1024*1024)
|
||||||
|
|
||||||
struct radeon_uvd {
|
struct radeon_uvd {
|
||||||
|
bool fw_header_present;
|
||||||
struct radeon_bo *vcpu_bo;
|
struct radeon_bo *vcpu_bo;
|
||||||
void *cpu_addr;
|
void *cpu_addr;
|
||||||
uint64_t gpu_addr;
|
uint64_t gpu_addr;
|
||||||
|
@ -34,6 +34,7 @@
|
|||||||
#include <drm/drm.h>
|
#include <drm/drm.h>
|
||||||
|
|
||||||
#include "radeon.h"
|
#include "radeon.h"
|
||||||
|
#include "radeon_ucode.h"
|
||||||
#include "r600d.h"
|
#include "r600d.h"
|
||||||
|
|
||||||
/* 1 second timeout */
|
/* 1 second timeout */
|
||||||
@ -47,7 +48,8 @@
|
|||||||
#define FIRMWARE_CYPRESS "radeon/CYPRESS_uvd.bin"
|
#define FIRMWARE_CYPRESS "radeon/CYPRESS_uvd.bin"
|
||||||
#define FIRMWARE_SUMO "radeon/SUMO_uvd.bin"
|
#define FIRMWARE_SUMO "radeon/SUMO_uvd.bin"
|
||||||
#define FIRMWARE_TAHITI "radeon/TAHITI_uvd.bin"
|
#define FIRMWARE_TAHITI "radeon/TAHITI_uvd.bin"
|
||||||
#define FIRMWARE_BONAIRE "radeon/BONAIRE_uvd.bin"
|
#define FIRMWARE_BONAIRE_LEGACY "radeon/BONAIRE_uvd.bin"
|
||||||
|
#define FIRMWARE_BONAIRE "radeon/bonaire_uvd.bin"
|
||||||
|
|
||||||
MODULE_FIRMWARE(FIRMWARE_R600);
|
MODULE_FIRMWARE(FIRMWARE_R600);
|
||||||
MODULE_FIRMWARE(FIRMWARE_RS780);
|
MODULE_FIRMWARE(FIRMWARE_RS780);
|
||||||
@ -56,6 +58,7 @@ MODULE_FIRMWARE(FIRMWARE_RV710);
|
|||||||
MODULE_FIRMWARE(FIRMWARE_CYPRESS);
|
MODULE_FIRMWARE(FIRMWARE_CYPRESS);
|
||||||
MODULE_FIRMWARE(FIRMWARE_SUMO);
|
MODULE_FIRMWARE(FIRMWARE_SUMO);
|
||||||
MODULE_FIRMWARE(FIRMWARE_TAHITI);
|
MODULE_FIRMWARE(FIRMWARE_TAHITI);
|
||||||
|
MODULE_FIRMWARE(FIRMWARE_BONAIRE_LEGACY);
|
||||||
MODULE_FIRMWARE(FIRMWARE_BONAIRE);
|
MODULE_FIRMWARE(FIRMWARE_BONAIRE);
|
||||||
|
|
||||||
static void radeon_uvd_idle_work_handler(struct work_struct *work);
|
static void radeon_uvd_idle_work_handler(struct work_struct *work);
|
||||||
@ -63,7 +66,7 @@ static void radeon_uvd_idle_work_handler(struct work_struct *work);
|
|||||||
int radeon_uvd_init(struct radeon_device *rdev)
|
int radeon_uvd_init(struct radeon_device *rdev)
|
||||||
{
|
{
|
||||||
unsigned long bo_size;
|
unsigned long bo_size;
|
||||||
const char *fw_name;
|
const char *fw_name = NULL, *legacy_fw_name = NULL;
|
||||||
int i, r;
|
int i, r;
|
||||||
|
|
||||||
INIT_DELAYED_WORK(&rdev->uvd.idle_work, radeon_uvd_idle_work_handler);
|
INIT_DELAYED_WORK(&rdev->uvd.idle_work, radeon_uvd_idle_work_handler);
|
||||||
@ -74,22 +77,22 @@ int radeon_uvd_init(struct radeon_device *rdev)
|
|||||||
case CHIP_RV670:
|
case CHIP_RV670:
|
||||||
case CHIP_RV620:
|
case CHIP_RV620:
|
||||||
case CHIP_RV635:
|
case CHIP_RV635:
|
||||||
fw_name = FIRMWARE_R600;
|
legacy_fw_name = FIRMWARE_R600;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case CHIP_RS780:
|
case CHIP_RS780:
|
||||||
case CHIP_RS880:
|
case CHIP_RS880:
|
||||||
fw_name = FIRMWARE_RS780;
|
legacy_fw_name = FIRMWARE_RS780;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case CHIP_RV770:
|
case CHIP_RV770:
|
||||||
fw_name = FIRMWARE_RV770;
|
legacy_fw_name = FIRMWARE_RV770;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case CHIP_RV710:
|
case CHIP_RV710:
|
||||||
case CHIP_RV730:
|
case CHIP_RV730:
|
||||||
case CHIP_RV740:
|
case CHIP_RV740:
|
||||||
fw_name = FIRMWARE_RV710;
|
legacy_fw_name = FIRMWARE_RV710;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case CHIP_CYPRESS:
|
case CHIP_CYPRESS:
|
||||||
@ -97,7 +100,7 @@ int radeon_uvd_init(struct radeon_device *rdev)
|
|||||||
case CHIP_JUNIPER:
|
case CHIP_JUNIPER:
|
||||||
case CHIP_REDWOOD:
|
case CHIP_REDWOOD:
|
||||||
case CHIP_CEDAR:
|
case CHIP_CEDAR:
|
||||||
fw_name = FIRMWARE_CYPRESS;
|
legacy_fw_name = FIRMWARE_CYPRESS;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case CHIP_SUMO:
|
case CHIP_SUMO:
|
||||||
@ -107,7 +110,7 @@ int radeon_uvd_init(struct radeon_device *rdev)
|
|||||||
case CHIP_BARTS:
|
case CHIP_BARTS:
|
||||||
case CHIP_TURKS:
|
case CHIP_TURKS:
|
||||||
case CHIP_CAICOS:
|
case CHIP_CAICOS:
|
||||||
fw_name = FIRMWARE_SUMO;
|
legacy_fw_name = FIRMWARE_SUMO;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case CHIP_TAHITI:
|
case CHIP_TAHITI:
|
||||||
@ -115,7 +118,7 @@ int radeon_uvd_init(struct radeon_device *rdev)
|
|||||||
case CHIP_PITCAIRN:
|
case CHIP_PITCAIRN:
|
||||||
case CHIP_ARUBA:
|
case CHIP_ARUBA:
|
||||||
case CHIP_OLAND:
|
case CHIP_OLAND:
|
||||||
fw_name = FIRMWARE_TAHITI;
|
legacy_fw_name = FIRMWARE_TAHITI;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case CHIP_BONAIRE:
|
case CHIP_BONAIRE:
|
||||||
@ -123,6 +126,7 @@ int radeon_uvd_init(struct radeon_device *rdev)
|
|||||||
case CHIP_KAVERI:
|
case CHIP_KAVERI:
|
||||||
case CHIP_HAWAII:
|
case CHIP_HAWAII:
|
||||||
case CHIP_MULLINS:
|
case CHIP_MULLINS:
|
||||||
|
legacy_fw_name = FIRMWARE_BONAIRE_LEGACY;
|
||||||
fw_name = FIRMWARE_BONAIRE;
|
fw_name = FIRMWARE_BONAIRE;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
@ -130,11 +134,34 @@ int radeon_uvd_init(struct radeon_device *rdev)
|
|||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
rdev->uvd.fw_header_present = false;
|
||||||
|
if (fw_name) {
|
||||||
|
/* Let's try to load the newer firmware first */
|
||||||
r = request_firmware(&rdev->uvd_fw, fw_name, rdev->dev);
|
r = request_firmware(&rdev->uvd_fw, fw_name, rdev->dev);
|
||||||
if (r) {
|
if (r) {
|
||||||
dev_err(rdev->dev, "radeon_uvd: Can't load firmware \"%s\"\n",
|
dev_err(rdev->dev, "radeon_uvd: Can't load firmware \"%s\"\n",
|
||||||
fw_name);
|
fw_name);
|
||||||
|
} else {
|
||||||
|
r = radeon_ucode_validate(rdev->uvd_fw);
|
||||||
|
if (r)
|
||||||
return r;
|
return r;
|
||||||
|
|
||||||
|
rdev->uvd.fw_header_present = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* In case there is only legacy firmware, or we encounter an error
|
||||||
|
* while loading the new firmware, we fall back to loading the legacy
|
||||||
|
* firmware now.
|
||||||
|
*/
|
||||||
|
if (!fw_name || r) {
|
||||||
|
r = request_firmware(&rdev->uvd_fw, legacy_fw_name, rdev->dev);
|
||||||
|
if (r) {
|
||||||
|
dev_err(rdev->dev, "radeon_uvd: Can't load firmware \"%s\"\n",
|
||||||
|
legacy_fw_name);
|
||||||
|
return r;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
bo_size = RADEON_GPU_PAGE_ALIGN(rdev->uvd_fw->size + 8) +
|
bo_size = RADEON_GPU_PAGE_ALIGN(rdev->uvd_fw->size + 8) +
|
||||||
|
@ -41,7 +41,13 @@ int uvd_v4_2_resume(struct radeon_device *rdev)
|
|||||||
uint32_t size;
|
uint32_t size;
|
||||||
|
|
||||||
/* programm the VCPU memory controller bits 0-27 */
|
/* programm the VCPU memory controller bits 0-27 */
|
||||||
|
|
||||||
|
/* skip over the header of the new firmware format */
|
||||||
|
if (rdev->uvd.fw_header_present)
|
||||||
|
addr = (rdev->uvd.gpu_addr + 0x200) >> 3;
|
||||||
|
else
|
||||||
addr = rdev->uvd.gpu_addr >> 3;
|
addr = rdev->uvd.gpu_addr >> 3;
|
||||||
|
|
||||||
size = RADEON_GPU_PAGE_ALIGN(rdev->uvd_fw->size + 4) >> 3;
|
size = RADEON_GPU_PAGE_ALIGN(rdev->uvd_fw->size + 4) >> 3;
|
||||||
WREG32(UVD_VCPU_CACHE_OFFSET0, addr);
|
WREG32(UVD_VCPU_CACHE_OFFSET0, addr);
|
||||||
WREG32(UVD_VCPU_CACHE_SIZE0, size);
|
WREG32(UVD_VCPU_CACHE_SIZE0, size);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user