mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2026-05-07 13:57:54 -04:00
drm/amd/pm: Use devm_i2c_add_adapter() in the V13_0_6 smu
The I2C init for V13_0_6 uses i2c_add_adapter() and i2c_del_adapter(), this commit replaces the use of these two functions with devm_i2c_add_adapter(). Notice that V13_0_6 init initializes multiple I2C buses in a loop; if something goes wrong, the previous adapters are removed, and the amdgpu load is interrupted. Since I2C init is required for the correct load of amdgpu, it is safe to rely on devm_i2c_add_adapter() to handle any previously initialized I2C adapter. Signed-off-by: Rodrigo Siqueira <siqueira@igalia.com> Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
This commit is contained in:
committed by
Alex Deucher
parent
4970883abd
commit
c32da00612
@@ -2494,10 +2494,10 @@ static int smu_v13_0_6_i2c_control_init(struct smu_context *smu)
|
||||
control->quirks = &smu_v13_0_6_i2c_control_quirks;
|
||||
i2c_set_adapdata(control, smu_i2c);
|
||||
|
||||
res = i2c_add_adapter(control);
|
||||
res = devm_i2c_add_adapter(adev->dev, control);
|
||||
if (res) {
|
||||
DRM_ERROR("Failed to register hw i2c, err: %d\n", res);
|
||||
goto Out_err;
|
||||
return res;
|
||||
}
|
||||
}
|
||||
|
||||
@@ -2505,27 +2505,12 @@ static int smu_v13_0_6_i2c_control_init(struct smu_context *smu)
|
||||
adev->pm.fru_eeprom_i2c_bus = &adev->pm.smu_i2c[0].adapter;
|
||||
|
||||
return 0;
|
||||
Out_err:
|
||||
for ( ; i >= 0; i--) {
|
||||
struct amdgpu_smu_i2c_bus *smu_i2c = &adev->pm.smu_i2c[i];
|
||||
struct i2c_adapter *control = &smu_i2c->adapter;
|
||||
|
||||
i2c_del_adapter(control);
|
||||
}
|
||||
return res;
|
||||
}
|
||||
|
||||
static void smu_v13_0_6_i2c_control_fini(struct smu_context *smu)
|
||||
{
|
||||
struct amdgpu_device *adev = smu->adev;
|
||||
int i;
|
||||
|
||||
for (i = 0; i < MAX_SMU_I2C_BUSES; i++) {
|
||||
struct amdgpu_smu_i2c_bus *smu_i2c = &adev->pm.smu_i2c[i];
|
||||
struct i2c_adapter *control = &smu_i2c->adapter;
|
||||
|
||||
i2c_del_adapter(control);
|
||||
}
|
||||
adev->pm.ras_eeprom_i2c_bus = NULL;
|
||||
adev->pm.fru_eeprom_i2c_bus = NULL;
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user