--- /dev/null
+From john.stultz@linaro.org  Tue Feb 11 10:07:48 2014
+From: John Stultz <john.stultz@linaro.org>
+Date: Mon, 10 Feb 2014 13:16:29 -0800
+Subject: 3.4.y: timekeeping: fix 32-bit overflow in get_monotonic_boottime
+To: stable <stable@vger.kernel.org>
+Cc: Colin Cross <ccross@android.com>, John Stultz <john.stultz@linaro.org>
+Message-ID: <1392066989-5113-4-git-send-email-john.stultz@linaro.org>
+
+From: Colin Cross <ccross@android.com>
+
+fixed upstream in v3.6 by ec145babe754f9ea1079034a108104b6001e001c
+
+get_monotonic_boottime adds three nanonsecond values stored
+in longs, followed by an s64.  If the long values are all
+close to 1e9 the first three additions can overflow and
+become negative when added to the s64.  Cast the first
+value to s64 so that all additions are 64 bit.
+
+Signed-off-by: Colin Cross <ccross@android.com>
+[jstultz: Fished this out of the AOSP commong.git tree. This was
+fixed upstream in v3.6 by ec145babe754f9ea1079034a108104b6001e001c]
+Signed-off-by: John Stultz <john.stultz@linaro.org>
+Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
+---
+ kernel/time/timekeeping.c |    2 +-
+ 1 file changed, 1 insertion(+), 1 deletion(-)
+
+--- a/kernel/time/timekeeping.c
++++ b/kernel/time/timekeeping.c
+@@ -1197,7 +1197,7 @@ void get_monotonic_boottime(struct times
+       } while (read_seqretry(&timekeeper.lock, seq));
+ 
+       set_normalized_timespec(ts, ts->tv_sec + tomono.tv_sec + sleep.tv_sec,
+-                      ts->tv_nsec + tomono.tv_nsec + sleep.tv_nsec + nsecs);
++              (s64)ts->tv_nsec + tomono.tv_nsec + sleep.tv_nsec + nsecs);
+ }
+ EXPORT_SYMBOL_GPL(get_monotonic_boottime);
+