diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2012-10-02 20:26:42 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2012-10-02 20:26:42 -0400 |
commit | 7fe0b14b725d6d09a1d9e1409bd465cb88b587f9 (patch) | |
tree | 89b5ffca03145618da92c75fb3cc1dda87dbb924 /drivers/clk | |
parent | 7a9a2970b5c1c2ce73d4bb84edaa7ebf13e0c841 (diff) | |
parent | 536a53a300d0d40152796eefb0a9e6e36ca37f7d (diff) |
Merge tag 'spi-3.7' of git://git.kernel.org/pub/scm/linux/kernel/git/broonie/misc
Pull spi updates from Mark Brown:
"No framework work here, only a bunch of driver updates of varying
sizes:
- Factoring out of the core hardware support from the MXS MMC driver
by Marek Vasut to allow the hardware to also be used for SPI.
- Lots of error handling cleanups from Guenter Roeck
- Removal of the existing Tegra driver which is quite comprehensively
broken as detailed in the changelog for the removal.
- DT suppport for the PL022 and GPIO drivers.
- pinctrl support for OMAP and PL022."
Pulling from Mark Brown as Grant Likely is still busy moving.
* tag 'spi-3.7' of git://git.kernel.org/pub/scm/linux/kernel/git/broonie/misc: (53 commits)
spi: remove completely broken Tegra driver
spi/imx: set the inactive state of the clock according to the clock polarity
spi/pl022: get/put resources on suspend/resume
spi/pl022: use more managed resources
spi/pl022: Devicetree support w/o platform data
spi/s3c64xx: Don't free controller_data on non-dt platforms
spi: omap2-mcspi: add pinctrl support
spi/pl022: adopt pinctrl support
spi: omap2-mcspi: Cleanup the omap2_mcspi_txrx_dma function
spi/gpio: Fix stub for spi_gpio_probe_dt()
spi/mxs: Make the SPI block clock speed configurable via DT
spi: spi-sh-hspi: drop frees of devm_ alloc'd data
spi/pl022: Fix chipselects pointer computation
spi: spi-tle62x0: Use module_spi_driver macro
mxs/spi: Rework the mxs_ssp_timeout to be more readable
mxs/spi: Decrement the DMA/PIO border
mxs/spi: Increment the transfer length only if transfer succeeded
mxs/spi: Fix issues when doing long continuous transfer
spi: spi-gpio: Add DT bindings
spi: spi-gpio: store chipselect information in private structure
...
Diffstat (limited to 'drivers/clk')
-rw-r--r-- | drivers/clk/mxs/Makefile | 2 | ||||
-rw-r--r-- | drivers/clk/mxs/clk-ssp.c | 62 |
2 files changed, 63 insertions, 1 deletions
diff --git a/drivers/clk/mxs/Makefile b/drivers/clk/mxs/Makefile index 7bedeec08524..a6a22237e860 100644 --- a/drivers/clk/mxs/Makefile +++ b/drivers/clk/mxs/Makefile | |||
@@ -2,7 +2,7 @@ | |||
2 | # Makefile for mxs specific clk | 2 | # Makefile for mxs specific clk |
3 | # | 3 | # |
4 | 4 | ||
5 | obj-y += clk.o clk-pll.o clk-ref.o clk-div.o clk-frac.o | 5 | obj-y += clk.o clk-pll.o clk-ref.o clk-div.o clk-frac.o clk-ssp.o |
6 | 6 | ||
7 | obj-$(CONFIG_SOC_IMX23) += clk-imx23.o | 7 | obj-$(CONFIG_SOC_IMX23) += clk-imx23.o |
8 | obj-$(CONFIG_SOC_IMX28) += clk-imx28.o | 8 | obj-$(CONFIG_SOC_IMX28) += clk-imx28.o |
diff --git a/drivers/clk/mxs/clk-ssp.c b/drivers/clk/mxs/clk-ssp.c new file mode 100644 index 000000000000..af7bdbf9ebd7 --- /dev/null +++ b/drivers/clk/mxs/clk-ssp.c | |||
@@ -0,0 +1,62 @@ | |||
1 | /* | ||
2 | * Copyright 2012 DENX Software Engineering, GmbH | ||
3 | * | ||
4 | * Pulled from code: | ||
5 | * Portions copyright (C) 2003 Russell King, PXA MMCI Driver | ||
6 | * Portions copyright (C) 2004-2005 Pierre Ossman, W83L51xD SD/MMC driver | ||
7 | * | ||
8 | * Copyright 2008 Embedded Alley Solutions, Inc. | ||
9 | * Copyright 2009-2011 Freescale Semiconductor, Inc. | ||
10 | * | ||
11 | * The code contained herein is licensed under the GNU General Public | ||
12 | * License. You may obtain a copy of the GNU General Public License | ||
13 | * Version 2 or later at the following locations: | ||
14 | * | ||
15 | * http://www.opensource.org/licenses/gpl-license.html | ||
16 | * http://www.gnu.org/copyleft/gpl.html | ||
17 | */ | ||
18 | |||
19 | #include <linux/kernel.h> | ||
20 | #include <linux/init.h> | ||
21 | #include <linux/clk.h> | ||
22 | #include <linux/module.h> | ||
23 | #include <linux/device.h> | ||
24 | #include <linux/io.h> | ||
25 | #include <linux/spi/mxs-spi.h> | ||
26 | |||
27 | void mxs_ssp_set_clk_rate(struct mxs_ssp *ssp, unsigned int rate) | ||
28 | { | ||
29 | unsigned int ssp_clk, ssp_sck; | ||
30 | u32 clock_divide, clock_rate; | ||
31 | u32 val; | ||
32 | |||
33 | ssp_clk = clk_get_rate(ssp->clk); | ||
34 | |||
35 | for (clock_divide = 2; clock_divide <= 254; clock_divide += 2) { | ||
36 | clock_rate = DIV_ROUND_UP(ssp_clk, rate * clock_divide); | ||
37 | clock_rate = (clock_rate > 0) ? clock_rate - 1 : 0; | ||
38 | if (clock_rate <= 255) | ||
39 | break; | ||
40 | } | ||
41 | |||
42 | if (clock_divide > 254) { | ||
43 | dev_err(ssp->dev, | ||
44 | "%s: cannot set clock to %d\n", __func__, rate); | ||
45 | return; | ||
46 | } | ||
47 | |||
48 | ssp_sck = ssp_clk / clock_divide / (1 + clock_rate); | ||
49 | |||
50 | val = readl(ssp->base + HW_SSP_TIMING(ssp)); | ||
51 | val &= ~(BM_SSP_TIMING_CLOCK_DIVIDE | BM_SSP_TIMING_CLOCK_RATE); | ||
52 | val |= BF_SSP(clock_divide, TIMING_CLOCK_DIVIDE); | ||
53 | val |= BF_SSP(clock_rate, TIMING_CLOCK_RATE); | ||
54 | writel(val, ssp->base + HW_SSP_TIMING(ssp)); | ||
55 | |||
56 | ssp->clk_rate = ssp_sck; | ||
57 | |||
58 | dev_dbg(ssp->dev, | ||
59 | "%s: clock_divide %d, clock_rate %d, ssp_clk %d, rate_actual %d, rate_requested %d\n", | ||
60 | __func__, clock_divide, clock_rate, ssp_clk, ssp_sck, rate); | ||
61 | } | ||
62 | EXPORT_SYMBOL_GPL(mxs_ssp_set_clk_rate); | ||