It's worth noting here that I don't have a vega20 card to test with, so it might be prudent to get a Tested-by from someone that has access to one. It *should* work since it's so similar to the navi10 code, but it is moderately un-tested. On 1/29/20 11:17 AM, Alex Deucher wrote: > From: Matt Coffin <mcoffin13@xxxxxxxxx> > > Previously, the syfs functionality for restoring the default powerplay > table was sourcing it's information from the currently-staged powerplay > table. > > This patch adds a step to cache the first overdrive table that we see on > boot, so that it can be used later to "restore" the powerplay table > > v2: sqaush my original with Matt's fix > > Bug: https://gitlab.freedesktop.org/drm/amd/issues/1020 > Signed-off-by: Matt Coffin <mcoffin13@xxxxxxxxx> > Reviewed-by: Alex Deucher <alexander.deucher@xxxxxxx> > Signed-off-by: Alex Deucher <alexander.deucher@xxxxxxx> > --- > .../gpu/drm/amd/powerplay/inc/amdgpu_smu.h | 1 + > drivers/gpu/drm/amd/powerplay/navi10_ppt.c | 7 +++++ > drivers/gpu/drm/amd/powerplay/smu_v11_0.c | 6 ++++ > drivers/gpu/drm/amd/powerplay/vega20_ppt.c | 28 ++++++------------- > 4 files changed, 22 insertions(+), 20 deletions(-) > > diff --git a/drivers/gpu/drm/amd/powerplay/inc/amdgpu_smu.h b/drivers/gpu/drm/amd/powerplay/inc/amdgpu_smu.h > index b0591a8dda41..1e33c3e9b98d 100644 > --- a/drivers/gpu/drm/amd/powerplay/inc/amdgpu_smu.h > +++ b/drivers/gpu/drm/amd/powerplay/inc/amdgpu_smu.h > @@ -273,6 +273,7 @@ struct smu_table_context > uint8_t thermal_controller_type; > > void *overdrive_table; > + void *boot_overdrive_table; > }; > > struct smu_dpm_context { > diff --git a/drivers/gpu/drm/amd/powerplay/navi10_ppt.c b/drivers/gpu/drm/amd/powerplay/navi10_ppt.c > index d2d45181ae23..26cfccc57331 100644 > --- a/drivers/gpu/drm/amd/powerplay/navi10_ppt.c > +++ b/drivers/gpu/drm/amd/powerplay/navi10_ppt.c > @@ -2063,6 +2063,13 @@ static int navi10_od_edit_dpm_table(struct smu_context *smu, enum PP_OD_DPM_TABL > return ret; > od_table->UclkFmax = input[1]; > break; > + case PP_OD_RESTORE_DEFAULT_TABLE: > + if (!(table_context->overdrive_table && table_context->boot_overdrive_table)) { > + pr_err("Overdrive table was not initialized!\n"); > + return -EINVAL; > + } > + memcpy(table_context->overdrive_table, table_context->boot_overdrive_table, sizeof(OverDriveTable_t)); > + break; > case PP_OD_COMMIT_DPM_TABLE: > navi10_dump_od_table(od_table); > ret = smu_update_table(smu, SMU_TABLE_OVERDRIVE, 0, (void *)od_table, true); > diff --git a/drivers/gpu/drm/amd/powerplay/smu_v11_0.c b/drivers/gpu/drm/amd/powerplay/smu_v11_0.c > index 02f8c9cb89d9..0dc49479a7eb 100644 > --- a/drivers/gpu/drm/amd/powerplay/smu_v11_0.c > +++ b/drivers/gpu/drm/amd/powerplay/smu_v11_0.c > @@ -1882,6 +1882,12 @@ int smu_v11_0_set_default_od_settings(struct smu_context *smu, bool initialize, > pr_err("Failed to export overdrive table!\n"); > return ret; > } > + if (!table_context->boot_overdrive_table) { > + table_context->boot_overdrive_table = kmemdup(table_context->overdrive_table, overdrive_table_size, GFP_KERNEL); > + if (!table_context->boot_overdrive_table) { > + return -ENOMEM; > + } > + } > } > ret = smu_update_table(smu, SMU_TABLE_OVERDRIVE, 0, table_context->overdrive_table, true); > if (ret) { > diff --git a/drivers/gpu/drm/amd/powerplay/vega20_ppt.c b/drivers/gpu/drm/amd/powerplay/vega20_ppt.c > index 38febd5ca4da..4ad8d6c14ee5 100644 > --- a/drivers/gpu/drm/amd/powerplay/vega20_ppt.c > +++ b/drivers/gpu/drm/amd/powerplay/vega20_ppt.c > @@ -1706,22 +1706,11 @@ static int vega20_set_default_od_settings(struct smu_context *smu, > struct smu_table_context *table_context = &smu->smu_table; > int ret; > > - if (initialize) { > - if (table_context->overdrive_table) > - return -EINVAL; > - > - table_context->overdrive_table = kzalloc(sizeof(OverDriveTable_t), GFP_KERNEL); > - > - if (!table_context->overdrive_table) > - return -ENOMEM; > - > - ret = smu_update_table(smu, SMU_TABLE_OVERDRIVE, 0, > - table_context->overdrive_table, false); > - if (ret) { > - pr_err("Failed to export over drive table!\n"); > - return ret; > - } > + ret = smu_v11_0_set_default_od_settings(smu, initialize, sizeof(OverDriveTable_t)); > + if (ret) > + return ret; > > + if (initialize) { > ret = vega20_set_default_od8_setttings(smu); > if (ret) > return ret; > @@ -2778,12 +2767,11 @@ static int vega20_odn_edit_dpm_table(struct smu_context *smu, > break; > > case PP_OD_RESTORE_DEFAULT_TABLE: > - ret = smu_update_table(smu, SMU_TABLE_OVERDRIVE, 0, table_context->overdrive_table, false); > - if (ret) { > - pr_err("Failed to export over drive table!\n"); > - return ret; > + if (!(table_context->overdrive_table && table_context->boot_overdrive_table)) { > + pr_err("Overdrive table was not initialized!\n"); > + return -EINVAL; > } > - > + memcpy(table_context->overdrive_table, table_context->boot_overdrive_table, sizeof(OverDriveTable_t)); > break; > > case PP_OD_COMMIT_DPM_TABLE: >
Attachment:
signature.asc
Description: OpenPGP digital signature
_______________________________________________ amd-gfx mailing list amd-gfx@xxxxxxxxxxxxxxxxxxxxx https://lists.freedesktop.org/mailman/listinfo/amd-gfx