mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2025-01-24 00:29:27 +07:00
drm/radeon/dpm: cleanup a type issue with rv6xx_clocks_per_unit()
The rv6xx_clocks_per_unit() function pretends it can set flags in a u64 bitfield but really because "1" is an int it doesn't work for more than 32 bits. The only caller truncates the high bits away anyway. I've just changed it to be a u32. Signed-off-by: Dan Carpenter <dan.carpenter@oracle.com> Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
This commit is contained in:
parent
5c72273913
commit
43e917251a
@ -407,9 +407,9 @@ static void rv6xx_enable_engine_feedback_and_reference_sync(struct radeon_device
|
|||||||
WREG32_P(SPLL_CNTL_MODE, SPLL_DIV_SYNC, ~SPLL_DIV_SYNC);
|
WREG32_P(SPLL_CNTL_MODE, SPLL_DIV_SYNC, ~SPLL_DIV_SYNC);
|
||||||
}
|
}
|
||||||
|
|
||||||
static u64 rv6xx_clocks_per_unit(u32 unit)
|
static u32 rv6xx_clocks_per_unit(u32 unit)
|
||||||
{
|
{
|
||||||
u64 tmp = 1 << (2 * unit);
|
u32 tmp = 1 << (2 * unit);
|
||||||
|
|
||||||
return tmp;
|
return tmp;
|
||||||
}
|
}
|
||||||
@ -417,7 +417,7 @@ static u64 rv6xx_clocks_per_unit(u32 unit)
|
|||||||
static u32 rv6xx_scale_count_given_unit(struct radeon_device *rdev,
|
static u32 rv6xx_scale_count_given_unit(struct radeon_device *rdev,
|
||||||
u32 unscaled_count, u32 unit)
|
u32 unscaled_count, u32 unit)
|
||||||
{
|
{
|
||||||
u32 count_per_unit = (u32)rv6xx_clocks_per_unit(unit);
|
u32 count_per_unit = rv6xx_clocks_per_unit(unit);
|
||||||
|
|
||||||
return (unscaled_count + count_per_unit - 1) / count_per_unit;
|
return (unscaled_count + count_per_unit - 1) / count_per_unit;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user