diff options
author | Jarkko Nikula <jarkko.nikula@bitmer.com> | 2011-09-26 03:45:48 -0400 |
---|---|---|
committer | Tony Lindgren <tony@atomide.com> | 2011-09-26 20:48:59 -0400 |
commit | 09d28d2c19fe5c2d51b3133329584166dec89f86 (patch) | |
tree | 90f327bc24348d6f4157e305d4efe6ac6b834ecb /arch/arm/plat-omap/mcbsp.c | |
parent | 6e574123712b4fb89546b1304dd5438669057723 (diff) |
ARM: OMAP: mcbsp: Start generalize omap2_mcbsp_set_clks_src
This generalizes the omap2_mcbsp_set_clks_src implementation between generic
McBSP and OMAP2 specific McBSP code. Currently this function is used to
select either internal fclk or clks pin as a McBSP CLKS source on OMAP2+.
Implement generalization by having an optional set_clk_src function pointer
in platform data that is used to select parent for a given clock. Idea is to
pass higher level source clock name (later coming from client driver) that
platform specific code will map to platform specific clock name.
API cleanup between McBSP and client code comes later.
Signed-off-by: Jarkko Nikula <jarkko.nikula@bitmer.com>
Acked-by: Peter Ujfalusi <peter.ujfalusi@ti.com>
Tested-by: Janusz Krzysztofik <jkrzyszt@tis.icnet.pl>
Signed-off-by: Tony Lindgren <tony@atomide.com>
Diffstat (limited to 'arch/arm/plat-omap/mcbsp.c')
-rw-r--r-- | arch/arm/plat-omap/mcbsp.c | 33 |
1 files changed, 25 insertions, 8 deletions
diff --git a/arch/arm/plat-omap/mcbsp.c b/arch/arm/plat-omap/mcbsp.c index f92227f99f86..38b67d9be5b3 100644 --- a/arch/arm/plat-omap/mcbsp.c +++ b/arch/arm/plat-omap/mcbsp.c | |||
@@ -29,6 +29,9 @@ | |||
29 | struct omap_mcbsp **mcbsp_ptr; | 29 | struct omap_mcbsp **mcbsp_ptr; |
30 | int omap_mcbsp_count; | 30 | int omap_mcbsp_count; |
31 | 31 | ||
32 | #define omap_mcbsp_check_valid_id(id) (id < omap_mcbsp_count) | ||
33 | #define id_to_mcbsp_ptr(id) mcbsp_ptr[id]; | ||
34 | |||
32 | static void omap_mcbsp_write(struct omap_mcbsp *mcbsp, u16 reg, u32 val) | 35 | static void omap_mcbsp_write(struct omap_mcbsp *mcbsp, u16 reg, u32 val) |
33 | { | 36 | { |
34 | void __iomem *addr = mcbsp->io_base + reg * mcbsp->pdata->reg_step; | 37 | void __iomem *addr = mcbsp->io_base + reg * mcbsp->pdata->reg_step; |
@@ -894,18 +897,32 @@ void omap_mcbsp_stop(unsigned int id, int tx, int rx) | |||
894 | } | 897 | } |
895 | EXPORT_SYMBOL(omap_mcbsp_stop); | 898 | EXPORT_SYMBOL(omap_mcbsp_stop); |
896 | 899 | ||
897 | /* | ||
898 | * The following functions are only required on an OMAP1-only build. | ||
899 | * mach-omap2/mcbsp.c contains the real functions | ||
900 | */ | ||
901 | #ifndef CONFIG_ARCH_OMAP2PLUS | ||
902 | int omap2_mcbsp_set_clks_src(u8 id, u8 fck_src_id) | 900 | int omap2_mcbsp_set_clks_src(u8 id, u8 fck_src_id) |
903 | { | 901 | { |
904 | WARN(1, "%s: should never be called on an OMAP1-only kernel\n", | 902 | struct omap_mcbsp *mcbsp; |
905 | __func__); | 903 | const char *src; |
906 | return -EINVAL; | 904 | |
905 | if (!omap_mcbsp_check_valid_id(id)) { | ||
906 | pr_err("%s: Invalid id (%d)\n", __func__, id + 1); | ||
907 | return -EINVAL; | ||
908 | } | ||
909 | mcbsp = id_to_mcbsp_ptr(id); | ||
910 | |||
911 | if (fck_src_id == MCBSP_CLKS_PAD_SRC) | ||
912 | src = "clks_ext"; | ||
913 | else if (fck_src_id == MCBSP_CLKS_PRCM_SRC) | ||
914 | src = "clks_fclk"; | ||
915 | else | ||
916 | return -EINVAL; | ||
917 | |||
918 | if (mcbsp->pdata->set_clk_src) | ||
919 | return mcbsp->pdata->set_clk_src(mcbsp->dev, mcbsp->fclk, src); | ||
920 | else | ||
921 | return -EINVAL; | ||
907 | } | 922 | } |
923 | EXPORT_SYMBOL(omap2_mcbsp_set_clks_src); | ||
908 | 924 | ||
925 | #ifndef CONFIG_ARCH_OMAP2PLUS | ||
909 | void omap2_mcbsp1_mux_clkr_src(u8 mux) | 926 | void omap2_mcbsp1_mux_clkr_src(u8 mux) |
910 | { | 927 | { |
911 | WARN(1, "%s: should never be called on an OMAP1-only kernel\n", | 928 | WARN(1, "%s: should never be called on an OMAP1-only kernel\n", |