1 From 6793b3cd5da817c4be218bd8632f07cf4d2b0d26 Mon Sep 17 00:00:00 2001
2 From: Hans de Goede <hdegoede@redhat.com>
3 Date: Wed, 19 Nov 2014 14:48:59 +0100
4 Subject: [PATCH] clk_mux: Fix set_parent doing the wrong thing when INDEX_BIT
7 If CLK_MUX_INDEX_BIT is set, then each bit turns on / off a single parent,
8 so theoretically multiple parents could be enabled at the same time, but in
9 practice only one bit should ever be 1. So to select parent 0, set
10 the register (*) to 0x01, to select parent 1 set it 0x02, parent 2, 0x04,
13 But the current code does:
15 if (mux->flags & CLK_MUX_INDEX_BIT)
16 index = (1 << ffs(index));
20 For an input index of 0, ffs returns 0, so we set the register
23 For an input index of 1, ffs returns 1, so we set the register
26 For an input index of 2, ffs returns 2, so we set the register
29 For an input index of 3, ffs returns 1, so we set the register
32 The code should simply be:
34 if (mux->flags & CLK_MUX_INDEX_BIT)
37 Which always does the right thing, this commit fixes this.
39 Signed-off-by: Hans de Goede <hdegoede@redhat.com>
40 Signed-off-by: Michael Turquette <mturquette@linaro.org>
42 drivers/clk/clk-mux.c | 2 +-
43 1 file changed, 1 insertion(+), 1 deletion(-)
45 --- a/drivers/clk/clk-mux.c
46 +++ b/drivers/clk/clk-mux.c
47 @@ -77,7 +77,7 @@ static int clk_mux_set_parent(struct clk
50 if (mux->flags & CLK_MUX_INDEX_BIT)
51 - index = (1 << ffs(index));
54 if (mux->flags & CLK_MUX_INDEX_ONE)