int wm_core_init(void) { int ret = 0; static char init_done; if (init_done) return WM_SUCCESS; wmstdio_init(UART0_ID, 0); ret = cli_init(); if (ret != WM_SUCCESS) { init_e("Cli init failed."); goto out; } ret = wmtime_init(); if (ret != WM_SUCCESS) { init_e("Wmtime init failed."); goto out; } ret = pm_init(); if (ret != WM_SUCCESS) { init_e("Power manager init failed."); goto out; } ret = healthmon_init(); if (ret != WM_SUCCESS) { init_e("Healthmon init failed."); goto out; } boot_report_flags(); wmlog("boot", "Reset Cause Register: 0x%x", boot_reset_cause()); if (boot_reset_cause() & (1<<5)) wmlog("boot", " - Watchdog reset bit is set"); /* Read partition table layout from flash */ part_init(); out: if (ret == WM_SUCCESS) init_done = 1; return ret; }
static void modules_init() { int ret; ret = wmstdio_init(UART0_ID, 0); if (ret != WM_SUCCESS) { wmprintf("Error: wmstdio_init failed\r\n"); appln_critical_error_handler((void *) -WM_FAIL); } ret = cli_init(); if (ret != WM_SUCCESS) { wmprintf("Error: cli_init failed\r\n"); appln_critical_error_handler((void *) -WM_FAIL); } ret = wlan_cli_init(); if (ret != WM_SUCCESS) { wmprintf("Error: wlan_cli_init failed\r\n"); appln_critical_error_handler((void *) -WM_FAIL); } ret = pm_cli_init(); if (ret != WM_SUCCESS) { wmprintf("Error: pm_cli_init failed\r\n"); appln_critical_error_handler((void *) -WM_FAIL); } /* Initialize time subsystem. * * Initializes time to 1/1/1970 epoch 0. */ ret = wmtime_init(); if (ret != WM_SUCCESS) { wmprintf("Error: wmtime_init failed\r\n"); appln_critical_error_handler((void *) -WM_FAIL); } return; }
static void modules_init() { int ret; struct partition_entry *p; flash_desc_t fl; /* * Initialize wmstdio prints */ ret = wmstdio_init(UART0_ID, 115200); if (ret != WM_SUCCESS) { appln_critical_error_handler((void *) -WM_FAIL); } /* Initialize time subsystem. * * Initializes time to 1/1/1970 epoch 0. */ ret = wmtime_init(); if (ret != WM_SUCCESS) { wmprintf("Error: wmtime_init failed"); appln_critical_error_handler((void *) -WM_FAIL); } /* * Initialize CLI Commands */ ret = cli_init(); if (ret != WM_SUCCESS) { LOG_ERROR("Error: cli_init failed"); appln_critical_error_handler((void *) -WM_FAIL); } /* Initialize the partition module */ ret = part_init(); if (ret != 0) { LOG_ERROR("Failed to initialize partition\r\n"); appln_critical_error_handler((void *) -WM_FAIL); } p = part_get_layout_by_id(FC_COMP_PSM, NULL); if (!p) { LOG_ERROR("Error: no psm partition found"); appln_critical_error_handler((void *) -WM_FAIL); } part_to_flash_desc(p, &fl); #if defined CONFIG_CPU_MC200 && defined CONFIG_WiFi_8801 //check psm _format psm_format_check(&fl); #endif /* Initilize psm module */ ret = app_psm_init(); if (ret != 0) { LOG_ERROR("Failed to initialize psm module\r\n"); appln_critical_error_handler((void *) -WM_FAIL); } wmprintf("\n\r"); wmprintf("_| _| _|_|_| _|_|_| _|_| \n\r"); wmprintf("_|_| _|_| _| _| _| _|\n\r"); wmprintf("_| _| _| _| _| _| _|\n\r"); wmprintf("_| _| _| _| _| _|\n\r"); wmprintf("_| _| _|_|_| _|_|_| _|_| \n\r"); print_versions(); read_provision_status(); #ifndef RELEASE /* Initilize cli for psm module */ ret = psm_cli_init(); if (ret != 0) { LOG_ERROR("Failed to register psm-cli commands\r\n"); appln_critical_error_handler((void *) -WM_FAIL); } #endif ret = gpio_drv_init(); if (ret != WM_SUCCESS) { LOG_ERROR("Error: gpio_drv_init failed"); appln_critical_error_handler((void *) -WM_FAIL); } ret = aes_drv_init(); if (ret != WM_SUCCESS) { LOG_ERROR("Error: aes drv init failed"); appln_critical_error_handler((void *) -WM_FAIL); } ret = factory_cli_init(); if (ret != 0) { LOG_ERROR("Error: factory_cli_init failed"); appln_critical_error_handler((void *) -WM_FAIL); } ret = miio_chip_rpc_init(); if (ret != 0) { LOG_ERROR("Error: miio_chip_rpc_cli_init failed"); appln_critical_error_handler((void *) -WM_FAIL); } #ifndef RELEASE ret = appln_cli_init(); if (ret != 0) { LOG_ERROR("Error: appln init failed"); appln_critical_error_handler((void *) -WM_FAIL); } #endif /* init add on interface */ init_addon_interface(); ret = ota_init(); if (ret != 0) { LOG_ERROR("Error: ota init failed"); appln_critical_error_handler((void *) -WM_FAIL); } #ifdef MIIO_COMMANDS ret = mcmd_create(UART1_ID); if (ret < 0) { LOG_ERROR("Error: miio command init failed(%d)\r\n", ret); appln_critical_error_handler((void *) -WM_FAIL); } #endif /* * Initialize Power Management Subsystem */ ret = pm_init(); if (ret != WM_SUCCESS) { LOG_ERROR("Error: pm_init failed"); appln_critical_error_handler((void *) -WM_FAIL); } }