platform: msm_shared: Implement watch dog driver in LK.
Enable wdog at the end of LK to catch early kernel crashes
Change-Id: Ica4077a2cec28f6ee83f7fcdbe04001681b635d9
diff --git a/platform/msm_shared/wdog.c b/platform/msm_shared/wdog.c
new file mode 100644
index 0000000..93a7309
--- /dev/null
+++ b/platform/msm_shared/wdog.c
@@ -0,0 +1,55 @@
+/* Copyright (c) 2015, The Linux Foundation. All rights reserved.
+
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions are
+ * met:
+ * * Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * * Redistributions in binary form must reproduce the above
+ * copyright notice, this list of conditions and the following
+ * disclaimer in the documentation and/or other materials provided
+ * with the distribution.
+ * * Neither the name of The Linux Foundation. nor the names of its
+ * contributors may be used to endorse or promote products derived
+ * from this software without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESS OR IMPLIED
+ * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
+ * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT
+ * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS
+ * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+ * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
+ * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
+ * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
+ * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
+ * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN
+ * IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ */
+
+#include <stdlib.h>
+#include <debug.h>
+#include <platform.h>
+#include <platform/iomap.h>
+#include <reg.h>
+#include <wdog.h>
+#include <target.h>
+
+void msm_wdog_init()
+{
+ uint32_t rc;
+
+ /* Set Bite and Bark times 10s */
+ writel(0x77FD3, APPS_WDOG_BARK_VAL_REG);
+ writel(0x77FD3, APPS_WDOG_BITE_VAL_REG);
+
+ /* Reset WDOG */
+ writel(1, APPS_WDOG_RESET_REG);
+
+ /* Enable WDOG */
+ writel((readl(APPS_WDOG_CTL_REG) | 0x1), APPS_WDOG_CTL_REG);
+
+ /* Set dload mode */
+ rc = set_download_mode(NORMAL_DLOAD);
+ if(rc)
+ dprintf(CRITICAL, "set_download_mode failed\n");
+}