The function calculateUtilizationRate(uint256 totalLiquidity, uint256 totalDebt) in ReserveLibrary.sol assumes that totalDebt and totalLiquidity are denominated in the same unit. This assumption is incorrect and leads to an inaccurate utilization rate calculation.
This issue arises because totalLiquidity represents the amount of crvUSD available for lending, whereas totalDebt is based on the DebtToken total supply. As a result, the utilization rate can be miscalculated, leading to incorrect interest rate dynamics.
How Liquidity is Tracked
The reserve.totalLiquidity variable represents the amount of crvUSD supplied by lenders and available for borrowing.
This can be confirmed by tracing the deposit flow in LendingPool.sol:
User deposits crvUSD: The deposit(uint256 amount) function takes a crvUSD amount as an argument.
Deposit is processed in ReserveLibrary.sol: The call to ReserveLibrary.deposit() ultimately updates reserve.totalLiquidity by adding or subtracting crvUSD values:
How Debt is Tracked
Borrowing in LendingPool.sol affects reserve.totalUsage, which is updated as follows:
Here, newTotalSupply corresponds to the total supply of DebtTokens
calculateUtilizationRate() treats totalLiquidity and totalDebt as if they are directly comparable. However, since totalDebt tracks DebtTokens while totalLiquidity tracks crvUSD, the function is mixing two different value units. This can lead to:
Incorrect Interest Rate Calculation: Since utilization rate impacts borrowing costs and lending returns, a miscalculated value can distort interest rates.
Potential Economic Exploit: If the system operates under incorrect utilization metrics, it may allow borrowers to exploit cheaper borrowing rates or cause lenders to receive lower-than-expected yields.
Risk of Liquidity Mismanagement: An inaccurate utilization rate could lead to improper liquidity management, either locking too much liquidity or failing to control lending properly.
manual review
Ensure Unit Consistency: Convert totalDebt into crvUSD before using it in utilization calculations.
Enhance Documentation: Clearly specify how totalLiquidity and totalDebt are measured to prevent further confusion.
The contest is live. Earn rewards by submitting a finding.
This is your time to appeal against judgements on your submissions.
Appeals are being carefully reviewed by our judges.