Commit f94582e4 authored by Kent Russell's avatar Kent Russell Committed by Alex Deucher

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: default avatarKent Russell <kent.russell@amd.com>
Reviewed-by: default avatarFelix Kuehling <Felix.Kuehling@amd.com>
Signed-off-by: default avatarAlex Deucher <alexander.deucher@amd.com>
parent 485d531c
...@@ -34,18 +34,31 @@ ...@@ -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 */
* struct atom_context *atom_ctx = adev->mode_info.atom_context;
* TODO: Add list of supported Arcturus DIDs once confirmed
/* VBIOS is of the format ###-DXXXYY-##. For SKU identification,
* we can use just the "DXXX" portion. If there were more models, we
* 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
*/ */
if ((adev->asic_type == CHIP_VEGA20 && adev->pdev->device == 0x66a0) || switch (adev->asic_type) {
(adev->asic_type == CHIP_VEGA20 && adev->pdev->device == 0x66a1) || case CHIP_VEGA20:
(adev->asic_type == CHIP_VEGA20 && adev->pdev->device == 0x66a4)) /* 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; return true;
else
return false; 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,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment