You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
33 lines
1.2 KiB
33 lines
1.2 KiB
From 04609953e11377c0705b0aba5c25ebdcbb9e4aa7 Mon Sep 17 00:00:00 2001
|
|
From: =?UTF-8?q?Emilio=20L=C3=B3pez?= <emilio@elopez.com.ar>
|
|
Date: Thu, 5 Sep 2013 19:47:20 -0300
|
|
Subject: [PATCH] clk: sunxi: factors: fix off-by-one masks
|
|
MIME-Version: 1.0
|
|
Content-Type: text/plain; charset=UTF-8
|
|
Content-Transfer-Encoding: 8bit
|
|
|
|
The previous code would generate one bit too long masks, and was
|
|
needlessly complicated. This patch replaces it by simpler code that can
|
|
generate the masks correctly.
|
|
|
|
Signed-off-by: Emilio López <emilio@elopez.com.ar>
|
|
---
|
|
drivers/clk/sunxi/clk-factors.c | 2 +-
|
|
1 file changed, 1 insertion(+), 1 deletion(-)
|
|
|
|
diff --git a/drivers/clk/sunxi/clk-factors.c b/drivers/clk/sunxi/clk-factors.c
|
|
index 88523f9..5687ac9 100644
|
|
--- a/drivers/clk/sunxi/clk-factors.c
|
|
+++ b/drivers/clk/sunxi/clk-factors.c
|
|
@@ -40,7 +40,7 @@ struct clk_factors {
|
|
|
|
#define to_clk_factors(_hw) container_of(_hw, struct clk_factors, hw)
|
|
|
|
-#define SETMASK(len, pos) (((-1U) >> (31-len)) << (pos))
|
|
+#define SETMASK(len, pos) (((1U << (len)) - 1) << (pos))
|
|
#define CLRMASK(len, pos) (~(SETMASK(len, pos)))
|
|
#define FACTOR_GET(bit, len, reg) (((reg) & SETMASK(len, bit)) >> (bit))
|
|
|
|
--
|
|
1.8.5.1
|
|
|
|
|