diff options
Diffstat (limited to 'patches/linux-3.12-rc4/0005-ARM-call-of_clk_init-from-default-time_init-handler.patch')
-rw-r--r-- | patches/linux-3.12-rc4/0005-ARM-call-of_clk_init-from-default-time_init-handler.patch | 75 |
1 files changed, 75 insertions, 0 deletions
diff --git a/patches/linux-3.12-rc4/0005-ARM-call-of_clk_init-from-default-time_init-handler.patch b/patches/linux-3.12-rc4/0005-ARM-call-of_clk_init-from-default-time_init-handler.patch new file mode 100644 index 0000000..a02a493 --- /dev/null +++ b/patches/linux-3.12-rc4/0005-ARM-call-of_clk_init-from-default-time_init-handler.patch @@ -0,0 +1,75 @@ +From: Sebastian Hesselbarth <sebastian.hesselbarth@gmail.com> +Date: Mon, 23 Sep 2013 09:54:30 +0200 +Subject: [PATCH] ARM: call of_clk_init from default time_init handler + +Most DT ARM machs require common clock providers initialized before timers. +Currently, arch/arm machs use .init_time to call of_clk_init right before +clocksource_of_init. This prevents to remove that callback and use the default +one instead. + +This patch adds a call to of_clk_init() to the default .init_time callback +for COMMON_CLK enabled machs to allow to remove custom callbacks where applicable. +While at it, also reorder includes alphabetically. + +Signed-off-by: Sebastian Hesselbarth <sebastian.hesselbarth@gmail.com> +Origin: id:1379922870-2325-1-git-send-email-sebastian.hesselbarth@gmail.com (v2) +--- + arch/arm/kernel/time.c | 29 +++++++++++++++++------------ + 1 file changed, 17 insertions(+), 12 deletions(-) + +diff --git a/arch/arm/kernel/time.c b/arch/arm/kernel/time.c +index 98aee32..829a96d 100644 +--- a/arch/arm/kernel/time.c ++++ b/arch/arm/kernel/time.c +@@ -11,25 +11,26 @@ + * This file contains the ARM-specific time handling details: + * reading the RTC at bootup, etc... + */ ++#include <linux/clk-provider.h> ++#include <linux/clocksource.h> ++#include <linux/errno.h> + #include <linux/export.h> +-#include <linux/kernel.h> +-#include <linux/interrupt.h> +-#include <linux/time.h> + #include <linux/init.h> ++#include <linux/interrupt.h> ++#include <linux/irq.h> ++#include <linux/kernel.h> ++#include <linux/profile.h> + #include <linux/sched.h> ++#include <linux/sched_clock.h> + #include <linux/smp.h> ++#include <linux/time.h> + #include <linux/timex.h> +-#include <linux/errno.h> +-#include <linux/profile.h> + #include <linux/timer.h> +-#include <linux/clocksource.h> +-#include <linux/irq.h> +-#include <linux/sched_clock.h> + +-#include <asm/thread_info.h> +-#include <asm/stacktrace.h> + #include <asm/mach/arch.h> + #include <asm/mach/time.h> ++#include <asm/stacktrace.h> ++#include <asm/thread_info.h> + + #if defined(CONFIG_RTC_DRV_CMOS) || defined(CONFIG_RTC_DRV_CMOS_MODULE) || \ + defined(CONFIG_NVRAM) || defined(CONFIG_NVRAM_MODULE) +@@ -116,8 +117,12 @@ int __init register_persistent_clock(clock_access_fn read_boot, + + void __init time_init(void) + { +- if (machine_desc->init_time) ++ if (machine_desc->init_time) { + machine_desc->init_time(); +- else ++ } else { ++#ifdef CONFIG_COMMON_CLK ++ of_clk_init(NULL); ++#endif + clocksource_of_init(); ++ } + } |