static void mg_task(void *arg) { LOG(LL_INFO, ("MG task running")); GPIO_IF_LedToggle(MCU_RED_LED_GPIO); osi_MsgQCreate(&s_v7_q, "MG", sizeof(struct event), 32 /* len */); sl_Start(NULL, NULL, NULL); data_init_sensors(TMP006_ADDR, BM222_ADDR); cc3200_fs_init(); #if defined(WIFI_STA_SSID) if (!wifi_setup_sta(WIFI_STA_SSID, WIFI_STA_PASS)) { LOG(LL_ERROR, ("Error setting up WiFi station")); } #elif defined(WIFI_AP_SSID) if (!wifi_setup_ap(WIFI_AP_SSID, WIFI_AP_PASS, WIFI_AP_CHAN)) { LOG(LL_ERROR, ("Error setting up WiFi AP")); } #else #error WiFi not configured #endif /* We don't need SimpleLink's web server. */ sl_NetAppStop(SL_NET_APP_HTTP_SERVER_ID); mg_mgr_init(&mg_mgr, NULL); const char *err = ""; struct mg_bind_opts opts; memset(&opts, 0, sizeof(opts)); opts.error_string = &err; struct mg_connection *nc = mg_bind(&mg_mgr, "80", mg_ev_handler); if (nc != NULL) { mg_set_protocol_http_websocket(nc); nc->ev_timer_time = mg_time(); /* Start data collection */ } else { LOG(LL_ERROR, ("Failed to create listener: %s", err)); } while (1) { struct event e; mg_mgr_poll(&mg_mgr, 0); if (osi_MsgQRead(&s_v7_q, &e, 1) != OSI_OK) continue; } }
static enum cc3200_init_result cc3200_init(void *arg) { mongoose_init(); if (miot_uart_init(0, miot_uart_default_config(), NULL, NULL) == NULL) { return CC3200_INIT_UART_INIT_FAILED; } if (miot_uart_init(1, miot_uart_default_config(), NULL, NULL) == NULL) { return CC3200_INIT_UART_INIT_FAILED; } if (strcmp(MIOT_APP, "mongoose-iot") != 0) { LOG(LL_INFO, ("%s %s (%s)", MIOT_APP, build_version, build_id)); } LOG(LL_INFO, ("Mongoose IoT Firmware %s (%s)", mg_build_version, mg_build_id)); LOG(LL_INFO, ("RAM: %d total, %d free", miot_get_heap_size(), miot_get_free_heap_size())); int r = start_nwp(); if (r < 0) { LOG(LL_ERROR, ("Failed to start NWP: %d", r)); return CC3200_INIT_FAILED_TO_START_NWP; } g_boot_cfg_idx = get_active_boot_cfg_idx(); if (g_boot_cfg_idx < 0 || read_boot_cfg(g_boot_cfg_idx, &g_boot_cfg) < 0) { return CC3200_INIT_FAILED_TO_READ_BOOT_CFG; } LOG(LL_INFO, ("Boot cfg %d: 0x%llx, 0x%u, %s @ 0x%08x, %s", g_boot_cfg_idx, g_boot_cfg.seq, g_boot_cfg.flags, g_boot_cfg.app_image_file, g_boot_cfg.app_load_addr, g_boot_cfg.fs_container_prefix)); if (g_boot_cfg.flags & BOOT_F_FIRST_BOOT) { /* Tombstone the current config. If anything goes wrong between now and * commit, next boot will use the old one. */ uint64_t saved_seq = g_boot_cfg.seq; g_boot_cfg.seq = BOOT_CFG_TOMBSTONE_SEQ; write_boot_cfg(&g_boot_cfg, g_boot_cfg_idx); g_boot_cfg.seq = saved_seq; } r = cc3200_fs_init(g_boot_cfg.fs_container_prefix); if (r < 0) { LOG(LL_ERROR, ("FS init error: %d", r)); return CC3200_INIT_FS_INIT_FAILED; } else { /* * We aim to maintain at most 3 FS containers at all times. * Delete inactive FS container in the inactive boot configuration. */ struct boot_cfg cfg; int inactive_idx = (g_boot_cfg_idx == 0 ? 1 : 0); if (read_boot_cfg(inactive_idx, &cfg) >= 0) { fs_delete_inactive_container(cfg.fs_container_prefix); } } #if MIOT_ENABLE_UPDATER if (g_boot_cfg.flags & BOOT_F_FIRST_BOOT) { LOG(LL_INFO, ("Applying update")); r = miot_upd_apply_update(); if (r < 0) { LOG(LL_ERROR, ("Failed to apply update: %d", r)); return CC3200_INIT_UPDATE_FAILED; } } #endif enum miot_init_result ir = mg_init(); if (ir != MIOT_INIT_OK) { LOG(LL_ERROR, ("%s init error: %d", "MG", ir)); return CC3200_INIT_MG_INIT_FAILED; } #if MIOT_ENABLE_JS struct v7 *v7 = s_v7 = init_v7(&arg); ir = miot_init_js_all(v7); if (ir != MIOT_INIT_OK) { LOG(LL_ERROR, ("%s init error: %d", "JS", ir)); return CC3200_INIT_MG_INIT_JS_FAILED; } #endif #if MIOT_ENABLE_JS miot_prompt_init(v7, get_cfg()->debug.stdout_uart); #endif return CC3200_INIT_OK; }