On Wed, Mar 18, 2020 at 5:08 PM Nick Desaulniers <ndesaulniers@xxxxxxxxxx> wrote: > > On Wed, Mar 18, 2020 at 2:05 PM Nathan Chancellor > <natechancellor@xxxxxxxxx> wrote: > > > > clang warns: > > > > drivers/gpu/drm/amd/amdgpu/gfx_v9_0.c:754:6: warning: variable 'shadow' > > is used uninitialized whenever 'if' condition is > > false [-Wsometimes-uninitialized] > > if (offset == grbm_cntl || offset == grbm_idx) > > ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ > > drivers/gpu/drm/amd/amdgpu/gfx_v9_0.c:757:6: note: uninitialized use > > occurs here > > if (shadow) { > > ^~~~~~ > > drivers/gpu/drm/amd/amdgpu/gfx_v9_0.c:754:2: note: remove the 'if' if > > its condition is always true > > if (offset == grbm_cntl || offset == grbm_idx) > > ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ > > drivers/gpu/drm/amd/amdgpu/gfx_v9_0.c:738:13: note: initialize the > > variable 'shadow' to silence this warning > > bool shadow; > > ^ > > = 0 > > 1 warning generated. > > > > shadow is only assigned in one condition and used as the condition for > > another if statement; combine the two if statements and remove shadow > > to make the code cleaner and resolve this warning. > > > > Fixes: 2e0cc4d48b91 ("drm/amdgpu: revise RLCG access path") > > Link: https://github.com/ClangBuiltLinux/linux/issues/936 > > Suggested-by: Joe Perches <joe@xxxxxxxxxxx> > > Reviewed-by: Nick Desaulniers <ndesaulniers@xxxxxxxxxx> > > Signed-off-by: Nathan Chancellor <natechancellor@xxxxxxxxx> Applied. thanks! Alex > > --- > > > > v1 -> v2: > > > > * Remove shadow altogether, as suggested by Joe Perches. > > * Add Nick's Reviewed-by, as I assume it still stands. > > yep, thanks > > > > > drivers/gpu/drm/amd/amdgpu/gfx_v9_0.c | 6 +----- > > 1 file changed, 1 insertion(+), 5 deletions(-) > > > > diff --git a/drivers/gpu/drm/amd/amdgpu/gfx_v9_0.c b/drivers/gpu/drm/amd/amdgpu/gfx_v9_0.c > > index 7bc2486167e7..496b9edca3c3 100644 > > --- a/drivers/gpu/drm/amd/amdgpu/gfx_v9_0.c > > +++ b/drivers/gpu/drm/amd/amdgpu/gfx_v9_0.c > > @@ -735,7 +735,6 @@ void gfx_v9_0_rlcg_wreg(struct amdgpu_device *adev, u32 offset, u32 v) > > static void *spare_int; > > static uint32_t grbm_cntl; > > static uint32_t grbm_idx; > > - bool shadow; > > > > scratch_reg0 = adev->rmmio + (adev->reg_offset[GC_HWIP][0][mmSCRATCH_REG0_BASE_IDX] + mmSCRATCH_REG0)*4; > > scratch_reg1 = adev->rmmio + (adev->reg_offset[GC_HWIP][0][mmSCRATCH_REG1_BASE_IDX] + mmSCRATCH_REG1)*4; > > @@ -751,10 +750,7 @@ void gfx_v9_0_rlcg_wreg(struct amdgpu_device *adev, u32 offset, u32 v) > > return; > > } > > > > - if (offset == grbm_cntl || offset == grbm_idx) > > - shadow = true; > > - > > - if (shadow) { > > + if (offset == grbm_cntl || offset == grbm_idx) { > > if (offset == grbm_cntl) > > writel(v, scratch_reg2); > > else if (offset == grbm_idx) > > -- > > 2.26.0.rc1 > > > > > -- > Thanks, > ~Nick Desaulniers > _______________________________________________ > 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