On Thu, Jun 4, 2020 at 12:47 AM Evan Quan <evan.quan@xxxxxxx> wrote: > > Since it is only several bytes in size. I think the subject and description should be clarified a bit. We are not allocating it on the stack. We are just moving the object to the smu structure allocation rather than allocating it dynamically at runtime. We always allocate it anyway so no need to handle it allocate it separately. With that fixed: Reviewed-by: Alex Deucher <alexander.deucher@xxxxxxx> > > Change-Id: Ie9df0db543fdd4cf5b963a286ef40dee03c436bf > Signed-off-by: Evan Quan <evan.quan@xxxxxxx> > Reviewed-by: Alex Deucher <alexander.deucher@xxxxxxx> > --- > drivers/gpu/drm/amd/powerplay/amdgpu_smu.c | 3 --- > drivers/gpu/drm/amd/powerplay/inc/amdgpu_smu.h | 2 +- > drivers/gpu/drm/amd/powerplay/smu_v11_0.c | 15 +++------------ > 3 files changed, 4 insertions(+), 16 deletions(-) > > diff --git a/drivers/gpu/drm/amd/powerplay/amdgpu_smu.c b/drivers/gpu/drm/amd/powerplay/amdgpu_smu.c > index 65f5edcaa405..23eb64ae7432 100644 > --- a/drivers/gpu/drm/amd/powerplay/amdgpu_smu.c > +++ b/drivers/gpu/drm/amd/powerplay/amdgpu_smu.c > @@ -1102,9 +1102,6 @@ static int smu_sw_fini(void *handle) > struct smu_context *smu = &adev->smu; > int ret; > > - kfree(smu->irq_source); > - smu->irq_source = NULL; > - > ret = smu_smc_table_sw_fini(smu); > if (ret) { > pr_err("Failed to sw fini smc table!\n"); > diff --git a/drivers/gpu/drm/amd/powerplay/inc/amdgpu_smu.h b/drivers/gpu/drm/amd/powerplay/inc/amdgpu_smu.h > index 5f5a210668a1..90bb61c159fb 100644 > --- a/drivers/gpu/drm/amd/powerplay/inc/amdgpu_smu.h > +++ b/drivers/gpu/drm/amd/powerplay/inc/amdgpu_smu.h > @@ -356,7 +356,7 @@ struct smu_baco_context > struct smu_context > { > struct amdgpu_device *adev; > - struct amdgpu_irq_src *irq_source; > + struct amdgpu_irq_src irq_source; > > const struct pptable_funcs *ppt_funcs; > struct mutex mutex; > diff --git a/drivers/gpu/drm/amd/powerplay/smu_v11_0.c b/drivers/gpu/drm/amd/powerplay/smu_v11_0.c > index 5f3125ec5850..6c53488acd68 100644 > --- a/drivers/gpu/drm/amd/powerplay/smu_v11_0.c > +++ b/drivers/gpu/drm/amd/powerplay/smu_v11_0.c > @@ -1174,7 +1174,7 @@ int smu_v11_0_enable_thermal_alert(struct smu_context *smu) > if (ret) > return ret; > > - ret = amdgpu_irq_get(adev, smu->irq_source, 0); > + ret = amdgpu_irq_get(adev, &smu->irq_source, 0); > if (ret) > return ret; > > @@ -1198,7 +1198,7 @@ int smu_v11_0_enable_thermal_alert(struct smu_context *smu) > > int smu_v11_0_disable_thermal_alert(struct smu_context *smu) > { > - return amdgpu_irq_put(smu->adev, smu->irq_source, 0); > + return amdgpu_irq_put(smu->adev, &smu->irq_source, 0); > } > > static uint16_t convert_to_vddc(uint8_t vid) > @@ -1615,18 +1615,9 @@ static const struct amdgpu_irq_src_funcs smu_v11_0_irq_funcs = > int smu_v11_0_register_irq_handler(struct smu_context *smu) > { > struct amdgpu_device *adev = smu->adev; > - struct amdgpu_irq_src *irq_src = smu->irq_source; > + struct amdgpu_irq_src *irq_src = &smu->irq_source; > int ret = 0; > > - /* already register */ > - if (irq_src) > - return 0; > - > - irq_src = kzalloc(sizeof(struct amdgpu_irq_src), GFP_KERNEL); > - if (!irq_src) > - return -ENOMEM; > - smu->irq_source = irq_src; > - > irq_src->num_types = 1; > irq_src->funcs = &smu_v11_0_irq_funcs; > > -- > 2.27.0 > > _______________________________________________ > amd-gfx mailing list > amd-gfx@xxxxxxxxxxxxxxxxxxxxx > https://lists.freedesktop.org/mailman/listinfo/amd-gfx _______________________________________________ amd-gfx mailing list amd-gfx@xxxxxxxxxxxxxxxxxxxxx https://lists.freedesktop.org/mailman/listinfo/amd-gfx