Checking program for RTC module inside CPU.
Dependents: RTC_w_COM Frequency_Counter_w_GPS_1PPS debug_tools Nucleo_RTC_Clock_setting ... more
Please refer below link.
http://developer.mbed.org/users/kenjiArai/notebook/nucleo-series-clock-structure-and-xtal-oscillation/
Revision 0:01ddb8e35845, committed 2014-11-01
- Comitter:
- kenjiArai
- Date:
- Sat Nov 01 00:03:16 2014 +0000
- Child:
- 1:921a188e61c0
- Commit message:
- Checking program for RTC module inside CPU. Only for Nucleo board. L152RE, F401 and F411
Changed in this revision
| CheckRTC.cpp | Show annotated file Show diff for this revision Revisions of this file |
| CheckRTC.h | Show annotated file Show diff for this revision Revisions of this file |
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/CheckRTC.cpp Sat Nov 01 00:03:16 2014 +0000
@@ -0,0 +1,178 @@
+/*
+ * mbed Library program
+ * Check RTC function and set proper clock if we can set
+ * ONLY FOR "Nucleo Board"
+ *
+ * Copyright (c) 2010-2014 Kenji Arai / JH1PJL
+ * http://www.page.sannet.ne.jp/kenjia/index.html
+ * http://mbed.org/users/kenjiArai/
+ * Created: October 24th, 2014
+ * Revised: November 1st, 2014
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED,
+ * INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE
+ * AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
+ * DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
+ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
+ */
+
+//#define DEBUG // use Communication with PC(UART)
+
+// Include ---------------------------------------------------------------------------------------
+#include "mbed.h"
+#include "CheckRTC.h"
+
+// Definition ------------------------------------------------------------------------------------
+#ifdef DEBUG
+#define BAUD(x) pcm.baud(x)
+#define GETC(x) pcm.getc(x)
+#define PUTC(x) pcm.putc(x)
+#define PRINTF(...) pcm.printf(__VA_ARGS__)
+#define READABLE(x) pcm.readable(x)
+#else
+#define BAUD(x) {;}
+#define GETC(x) {;}
+#define PUTC(x) {;}
+#define PRINTF(...) {;}
+#define READABLE(x) {;}
+#endif
+
+// Object ----------------------------------------------------------------------------------------
+#ifdef DEBUG
+Serial pcm(USBTX, USBRX);
+#endif
+//DigitalOut myled(LED1);
+//Timer t;
+
+// RAM -------------------------------------------------------------------------------------------
+
+// ROM / Constant data ---------------------------------------------------------------------------
+
+// Function prototypes ---------------------------------------------------------------------------
+#if defined(TARGET_NUCLEO_F401RE) || defined(TARGET_NUCLEO_F411RE) || defined(TARGET_NUCLEO_L152RE)
+static int32_t Set_RTC_LSI(void);
+static int32_t rtc_external_osc_init(void);
+static int32_t Set_RTC_LSE(void);
+#endif
+
+//-------------------------------------------------------------------------------------------------
+// Control Program
+//-------------------------------------------------------------------------------------------------
+int32_t CheckRTC()
+{
+#if defined(TARGET_NUCLEO_F401RE) || defined(TARGET_NUCLEO_F411RE) || defined(TARGET_NUCLEO_L152RE)
+ if (rtc_external_osc_init() == OK) {
+ return OK;
+ } else {
+ return NG;
+ }
+#elif defined(TARGET_LPC1768) || defined(TARGET_K64F)
+ return OK;
+#else
+ return UNKNOWN;
+#endif
+}
+
+#if defined(TARGET_NUCLEO_F401RE) || defined(TARGET_NUCLEO_F411RE) || defined(TARGET_NUCLEO_L152RE)
+int32_t Set_RTC_LSE(void)
+{
+ uint32_t timeout = 0;
+
+ //---------------------------- LSE Configuration -------------------------
+ // Enable Power Clock
+ __PWR_CLK_ENABLE();
+ // Enable write access to Backup domain
+ PWR->CR |= PWR_CR_DBP;
+ // Wait for Backup domain Write protection disable
+ timeout = HAL_GetTick() + DBP_TIMEOUT_VALUE;
+ while((PWR->CR & PWR_CR_DBP) == RESET) {
+ if(HAL_GetTick() >= timeout) {
+ PRINTF("Time-Out 1\r\n");
+ return NG;
+ }
+ }
+ // Reset LSEON and LSEBYP bits before configuring the LSE ----------------
+ __HAL_RCC_LSE_CONFIG(RCC_LSE_OFF);
+ // Get timeout
+ timeout = HAL_GetTick() + TIMEOUT;
+ // Wait till LSE is ready
+ while(__HAL_RCC_GET_FLAG(RCC_FLAG_LSERDY) != RESET) {
+ if(HAL_GetTick() >= timeout) {
+ PRINTF("Time-Out 2\r\n");
+ return NG;
+ }
+ }
+ // Set the new LSE configuration -----------------------------------------
+ __HAL_RCC_LSE_CONFIG(RCC_LSE_ON);
+ // Get timeout
+ timeout = HAL_GetTick() + TIMEOUT;
+ // Wait till LSE is ready
+ while(__HAL_RCC_GET_FLAG(RCC_FLAG_LSERDY) == RESET) {
+ if(HAL_GetTick() >= timeout) {
+ PRINTF("Time-Out 3\r\n");
+ return NG;
+ }
+ }
+ PRINTF("OK");
+ return OK;
+}
+
+int32_t Set_RTC_LSI(void)
+{
+ uint32_t timeout = 0;
+
+ // Enable Power clock
+ __PWR_CLK_ENABLE();
+ // Enable access to Backup domain
+ HAL_PWR_EnableBkUpAccess();
+ // Reset Backup domain
+ __HAL_RCC_BACKUPRESET_FORCE();
+ __HAL_RCC_BACKUPRESET_RELEASE();
+ // Enable Power Clock
+ __PWR_CLK_ENABLE();
+ // Enable write access to Backup domain
+ PWR->CR |= PWR_CR_DBP;
+ // Wait for Backup domain Write protection disable
+ timeout = HAL_GetTick() + DBP_TIMEOUT_VALUE;
+ while((PWR->CR & PWR_CR_DBP) == RESET) {
+ if(HAL_GetTick() >= timeout) {
+ return NG;
+ }
+ }
+ __HAL_RCC_LSE_CONFIG(RCC_LSE_OFF);
+ // Enable LSI
+ __HAL_RCC_LSI_ENABLE();
+ timeout = HAL_GetTick() + TIMEOUT;
+ // Wait till LSI is ready
+ while(__HAL_RCC_GET_FLAG(RCC_FLAG_LSIRDY) == RESET) {
+ if(HAL_GetTick() >= timeout) {
+ return NG;
+ }
+ }
+ // Connect LSI to RTC
+ __HAL_RCC_RTC_CLKPRESCALER(RCC_RTCCLKSOURCE_LSI);
+ __HAL_RCC_RTC_CONFIG(RCC_RTCCLKSOURCE_LSI);
+ return OK;
+}
+
+int32_t rtc_external_osc_init(void)
+{
+ // Enable Power clock
+ __PWR_CLK_ENABLE();
+ // Enable access to Backup domain
+ HAL_PWR_EnableBkUpAccess();
+ // Reset Backup domain
+ __HAL_RCC_BACKUPRESET_FORCE();
+ __HAL_RCC_BACKUPRESET_RELEASE();
+ // Enable LSE Oscillator
+ if (Set_RTC_LSE() == OK) {
+ // Connect LSE to RTC
+ __HAL_RCC_RTC_CLKPRESCALER(RCC_RTCCLKSOURCE_LSE);
+ __HAL_RCC_RTC_CONFIG(RCC_RTCCLKSOURCE_LSE);
+ return OK;
+ } else {
+ Set_RTC_LSI();
+ return NG;
+ }
+}
+#endif
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/CheckRTC.h Sat Nov 01 00:03:16 2014 +0000
@@ -0,0 +1,55 @@
+/*
+ * mbed Library program
+ * Check RTC function and set proper clock if we can set
+ * ONLY FOR "Nucleo Board"
+ *
+ * Copyright (c) 2010-2014 Kenji Arai / JH1PJL
+ * http://www.page.sannet.ne.jp/kenjia/index.html
+ * http://mbed.org/users/kenjiArai/
+ * Created: October 24th, 2014
+ * Revised: November 1st, 2014
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED,
+ * INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE
+ * AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
+ * DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
+ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
+ */
+
+#ifndef CHECK_RTC_H
+#define CHECK_RTC_H
+
+#include "mbed.h"
+
+#define TIMEOUT ((uint32_t)5000)
+
+enum {
+ UNKNOWN = -1,
+ NG =0,
+ OK
+};
+
+/** Checking program for RTC module inside CPU
+ * Latest Nucleo board has external LSE Crystal X2 but no proper setting both HW ans SW
+ * This program intends to use RTC with X2
+ *
+ * @code
+ * #include "mbed.h"
+ * #include "CheckRTC.h"
+ *
+ * int main() {
+ * time_t seconds;
+ *
+ * CheckRTC();
+ * printf("Time: %s", ctime(&seconds));
+ * }
+ * @endcode
+ */
+
+/** Check and Set RTC
+ * @param none
+ * @return if proper setting = OK, if not = NG and UNKNOWN-> no support this program
+ */
+int32_t CheckRTC(void);
+
+#endif // CHECK_RTC_H