From mboxrd@z Thu Jan 1 00:00:00 1970 From: segooon@gmail.com (Kulikov Vasiliy) Date: Thu, 15 Jul 2010 22:43:15 +0400 Subject: [PATCH 1/8] arm/mach-tegra: fix unsigned calcs Message-ID: <1279219395-12088-1-git-send-email-segooon@gmail.com> To: linux-arm-kernel@lists.infradead.org List-Id: linux-arm-kernel.lists.infradead.org divider_u71 is unsigned, so this check is buggy: if (divider_u71 - 2 > 255 || divider_u71 - 2 < 0) If divider_u71 is 0 or 1 both checks are lying. So, it does not produce a buggy answer, but it is confusing. Signed-off-by: Kulikov Vasiliy --- arch/arm/mach-tegra/tegra2_clocks.c | 2 +- 1 files changed, 1 insertions(+), 1 deletions(-) diff --git a/arch/arm/mach-tegra/tegra2_clocks.c b/arch/arm/mach-tegra/tegra2_clocks.c index 4261632..64df5b4 100644 --- a/arch/arm/mach-tegra/tegra2_clocks.c +++ b/arch/arm/mach-tegra/tegra2_clocks.c @@ -149,7 +149,7 @@ static int clk_div71_get_divider(struct clk *c, unsigned long rate) divider_u71 = DIV_ROUND_UP(c->rate * 2, rate); - if (divider_u71 - 2 > 255 || divider_u71 - 2 < 0) + if (divider_u71 > 2 + 255 || divider_u71 < 2) return -EINVAL; return divider_u71 - 2; -- 1.7.0.4