diff options
author | Viresh Kumar <viresh.kumar@st.com> | 2011-08-05 06:02:34 -0400 |
---|---|---|
committer | Vinod Koul <vinod.koul@intel.com> | 2011-08-25 10:03:38 -0400 |
commit | 48a59ef3579492855d41405f8bf0a2983e061976 (patch) | |
tree | 71f73aef26d74054dee11dcbeebdcd7a0ced57d7 | |
parent | b7b6018bad6fd7ebe5a78bda5f2a71a6ecf5406a (diff) |
dmaengine/amba-pl08x: Simplify pl08x_ensure_on()
Simply writing 1 on bit 0 is sufficient instead of reading and clearing bits.
Also as per manual, for bit 3-31 of DMACConfiguration register:
"read undefined, write as 0"
So, we must not rely on values read from this registers bit 3-31.
Signed-off-by: Viresh Kumar <viresh.kumar@st.com>
Acked-by: Linus Walleij <linus.walleij@linaro.org>
Signed-off-by: Vinod Koul <vinod.koul@intel.com>
-rw-r--r-- | drivers/dma/amba-pl08x.c | 8 |
1 files changed, 1 insertions, 7 deletions
diff --git a/drivers/dma/amba-pl08x.c b/drivers/dma/amba-pl08x.c index 5dd97f450925..d79688d64886 100644 --- a/drivers/dma/amba-pl08x.c +++ b/drivers/dma/amba-pl08x.c | |||
@@ -1502,13 +1502,7 @@ bool pl08x_filter_id(struct dma_chan *chan, void *chan_id) | |||
1502 | */ | 1502 | */ |
1503 | static void pl08x_ensure_on(struct pl08x_driver_data *pl08x) | 1503 | static void pl08x_ensure_on(struct pl08x_driver_data *pl08x) |
1504 | { | 1504 | { |
1505 | u32 val; | 1505 | writel(PL080_CONFIG_ENABLE, pl08x->base + PL080_CONFIG); |
1506 | |||
1507 | val = readl(pl08x->base + PL080_CONFIG); | ||
1508 | val &= ~(PL080_CONFIG_M2_BE | PL080_CONFIG_M1_BE | PL080_CONFIG_ENABLE); | ||
1509 | /* We implicitly clear bit 1 and that means little-endian mode */ | ||
1510 | val |= PL080_CONFIG_ENABLE; | ||
1511 | writel(val, pl08x->base + PL080_CONFIG); | ||
1512 | } | 1506 | } |
1513 | 1507 | ||
1514 | static void pl08x_unmap_buffers(struct pl08x_txd *txd) | 1508 | static void pl08x_unmap_buffers(struct pl08x_txd *txd) |