Merge remote-tracking branch 'moduleh/module.h-split'
[linux-2.6/next.git] / arch / arm / mach-omap2 / clock2xxx.c
blob80bb0f0e92e6e5c47b89fdd87df7eaed27a8e9f0
1 /*
2 * clock2xxx.c - OMAP2xxx-specific clock integration code
4 * Copyright (C) 2005-2008 Texas Instruments, Inc.
5 * Copyright (C) 2004-2010 Nokia Corporation
7 * Contacts:
8 * Richard Woodruff <r-woodruff2@ti.com>
9 * Paul Walmsley
11 * Based on earlier work by Tuukka Tikkanen, Tony Lindgren,
12 * Gordon McNutt and RidgeRun, Inc.
14 * This program is free software; you can redistribute it and/or modify
15 * it under the terms of the GNU General Public License version 2 as
16 * published by the Free Software Foundation.
18 #undef DEBUG
20 #include <linux/kernel.h>
21 #include <linux/errno.h>
22 #include <linux/clk.h>
23 #include <linux/io.h>
25 #include <plat/clock.h>
27 #include "clock.h"
28 #include "clock2xxx.h"
29 #include "cm.h"
30 #include "cm-regbits-24xx.h"
32 struct clk *vclk, *sclk, *dclk;
35 * Omap24xx specific clock functions
39 * Set clocks for bypass mode for reboot to work.
41 void omap2xxx_clk_prepare_for_reboot(void)
43 u32 rate;
45 if (vclk == NULL || sclk == NULL)
46 return;
48 rate = clk_get_rate(sclk);
49 clk_set_rate(vclk, rate);
53 * Switch the MPU rate if specified on cmdline. We cannot do this
54 * early until cmdline is parsed. XXX This should be removed from the
55 * clock code and handled by the OPP layer code in the near future.
57 static int __init omap2xxx_clk_arch_init(void)
59 int ret;
61 if (!cpu_is_omap24xx())
62 return 0;
64 ret = omap2_clk_switch_mpurate_at_boot("virt_prcm_set");
65 if (!ret)
66 omap2_clk_print_new_rates("sys_ck", "dpll_ck", "mpu_ck");
68 return ret;
71 arch_initcall(omap2xxx_clk_arch_init);