aspeed/smc: Fix possible integer overflow
authorCédric Le Goater <clg@redhat.com>
Fri, 12 Jul 2024 15:13:15 +0000 (17:13 +0200)
committerCédric Le Goater <clg@redhat.com>
Sun, 21 Jul 2024 05:46:38 +0000 (07:46 +0200)
commit13951ccfcdf0f31902a93859506ccf8c0ef66583
tree6d56e4a109b1d559f59f84a202546dd6bd74b1c3
parenta87a7c449e532130d4fa8faa391ff7e1f04ed660
aspeed/smc: Fix possible integer overflow

Coverity reports a possible integer overflow because routine
aspeeed_smc_hclk_divisor() has a codepath returning 0, which could
lead to an integer overflow when computing variable 'hclk_shift' in
the caller aspeed_smc_dma_calibration().

The value passed to aspeed_smc_hclk_divisor() is always between 0 and
15 and, in this case, there is always a matching hclk divisor. Remove
the return 0 and use g_assert_not_reached() instead.

Fixes: Coverity CID 1547822
Suggested-by: Peter Maydell <peter.maydell@linaro.org>
Signed-off-by: Cédric Le Goater <clg@redhat.com>
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
hw/ssi/aspeed_smc.c