drm/amdgpu: Use SKU instead of DID for FRU check v2

The VG20 DIDs 66a0, 66a1 and 66a4 are used for various SKUs that may or may
not have the FRU EEPROM on it. Parse the VBIOS to check for server SKU
variants (D131 or D134) until a more general solution can be determined.

v2: Remove string-based logic, correct the VBIOS string comment

Signed-off-by: Kent Russell <kent.russell@amd.com>
Reviewed-by: Felix Kuehling <Felix.Kuehling@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
This commit is contained in:
Kent Russell 2020-09-28 14:20:05 -04:00 committed by Alex Deucher
parent 485d531c69
commit f94582e4bc
1 changed files with 24 additions and 11 deletions

View File

@ -34,18 +34,31 @@
static bool is_fru_eeprom_supported(struct amdgpu_device *adev) static bool is_fru_eeprom_supported(struct amdgpu_device *adev)
{ {
/* TODO: Gaming SKUs don't have the FRU EEPROM. /* Only server cards have the FRU EEPROM
* Use this hack to address hangs on modprobe on gaming SKUs * TODO: See if we can figure this out dynamically instead of
* until a proper solution can be implemented by only supporting * having to parse VBIOS versions.
* the explicit chip IDs for VG20 Server cards
*
* TODO: Add list of supported Arcturus DIDs once confirmed
*/ */
if ((adev->asic_type == CHIP_VEGA20 && adev->pdev->device == 0x66a0) || struct atom_context *atom_ctx = adev->mode_info.atom_context;
(adev->asic_type == CHIP_VEGA20 && adev->pdev->device == 0x66a1) ||
(adev->asic_type == CHIP_VEGA20 && adev->pdev->device == 0x66a4)) /* VBIOS is of the format ###-DXXXYY-##. For SKU identification,
return true; * we can use just the "DXXX" portion. If there were more models, we
return false; * could convert the 3 characters to a hex integer and use a switch
* for ease/speed/readability. For now, 2 string comparisons are
* reasonable and not too expensive
*/
switch (adev->asic_type) {
case CHIP_VEGA20:
/* D161 and D163 are the VG20 server SKUs */
if (strnstr(atom_ctx->vbios_version, "D161",
sizeof(atom_ctx->vbios_version)) ||
strnstr(atom_ctx->vbios_version, "D163",
sizeof(atom_ctx->vbios_version)))
return true;
else
return false;
default:
return false;
}
} }
static int amdgpu_fru_read_eeprom(struct amdgpu_device *adev, uint32_t addrptr, static int amdgpu_fru_read_eeprom(struct amdgpu_device *adev, uint32_t addrptr,