Boot to (nonresponsive) Lua prompt on RTOS!

Uart driver currently disabled as it's not (yet) compatible with RTOS.

Running Lua task with excessive stack to avoid smashing it; need to work out
what's using so much stack space.

Changed some flash reading functions to not attempt to drop an entire 4k
flash page onto the stack.

Ensure the task pump doesn't attempt to retrieve from uninitialised queues.
This commit is contained in:
Johny Mattsson 2016-05-30 17:56:33 +10:00
parent 97568e98d9
commit 56789592fa
6 changed files with 59 additions and 14 deletions

View File

@ -129,8 +129,8 @@ static int docall (lua_State *L, int narg, int clear) {
static void print_version (lua_State *L) { static void print_version (lua_State *L) {
lua_pushliteral (L, "\n" NODE_VERSION " build " BUILD_DATE " powered by " LUA_RELEASE " on SDK "); lua_pushliteral (L, "\n" NODE_VERSION " build " BUILD_DATE " powered by " LUA_RELEASE " on RTOS-SDK ");
lua_pushstring (L, SDK_VERSION); lua_pushstring (L, system_get_sdk_version ());
lua_concat (L, 2); lua_concat (L, 2);
const char *msg = lua_tostring (L, -1); const char *msg = lua_tostring (L, -1);
l_message (NULL, msg); l_message (NULL, msg);

View File

@ -29,19 +29,31 @@ static int adc_init107( lua_State *L )
{ {
uint8_t byte107 = luaL_checkinteger (L, 1); uint8_t byte107 = luaL_checkinteger (L, 1);
int erridx = -1;
const char *errmsg[] = {
"out of memory",
"flash read error",
"flash erase error",
"flash write error"
};
#define return_error(idx) do { erridx = idx; goto out; } while (0)
uint32 init_sector = flash_safe_get_sec_num () - 4; uint32 init_sector = flash_safe_get_sec_num () - 4;
// Note 32bit alignment so we can safely cast to uint32 for the flash api char *init_data = malloc (SPI_FLASH_SEC_SIZE);
char init_data[SPI_FLASH_SEC_SIZE] __attribute__((aligned(4))); if (!init_data)
return_error(0);
if (SPI_FLASH_RESULT_OK != flash_safe_read ( if (SPI_FLASH_RESULT_OK != flash_safe_read (
init_sector * SPI_FLASH_SEC_SIZE, init_sector * SPI_FLASH_SEC_SIZE,
(uint32 *)init_data, sizeof(init_data))) (uint32 *)init_data, sizeof(init_data)))
return luaL_error(L, "flash read error"); return_error(1);
// If it's already the correct value, we don't need to force it // If it's already the correct value, we don't need to force it
if (init_data[107] == byte107) if (init_data[107] == byte107)
{ {
free (init_data);
lua_pushboolean (L, false); lua_pushboolean (L, false);
return 1; return 1;
} }
@ -49,16 +61,23 @@ static int adc_init107( lua_State *L )
// Nope, it differs, we need to rewrite it // Nope, it differs, we need to rewrite it
init_data[107] = byte107; init_data[107] = byte107;
if (SPI_FLASH_RESULT_OK != flash_safe_erase_sector (init_sector)) if (SPI_FLASH_RESULT_OK != flash_safe_erase_sector (init_sector))
return luaL_error(L, "flash erase error"); return_error(2);
if (SPI_FLASH_RESULT_OK != flash_safe_write ( if (SPI_FLASH_RESULT_OK != flash_safe_write (
init_sector * SPI_FLASH_SEC_SIZE, init_sector * SPI_FLASH_SEC_SIZE,
(uint32 *)init_data, sizeof(init_data))) (uint32 *)init_data, sizeof(init_data)))
return luaL_error(L, "flash write error"); return_error(3);
out:
free (init_data);
if (erridx >= 0)
return luaL_error(L, errmsg[erridx]);
else
{
lua_pushboolean (L, true); lua_pushboolean (L, true);
return 1; return 1;
} }
}
// Module function map // Module function map
static const LUA_REG_TYPE adc_map[] = { static const LUA_REG_TYPE adc_map[] = {

View File

@ -133,7 +133,10 @@ bool flash_rom_set_size_type(uint8_t size)
// Reboot required!!! // Reboot required!!!
// If you don't know what you're doing, your nodemcu may turn into stone ... // If you don't know what you're doing, your nodemcu may turn into stone ...
NODE_DBG("\nBEGIN SET FLASH HEADER\n"); NODE_DBG("\nBEGIN SET FLASH HEADER\n");
uint8_t data[SPI_FLASH_SEC_SIZE] ICACHE_STORE_ATTR; uint8_t *data = malloc (SPI_FLASH_SEC_SIZE);
if (!data)
return false;
if (SPI_FLASH_RESULT_OK == spi_flash_read(0, (uint32 *)data, SPI_FLASH_SEC_SIZE)) if (SPI_FLASH_RESULT_OK == spi_flash_read(0, (uint32 *)data, SPI_FLASH_SEC_SIZE))
{ {
((SPIFlashInfo *)(&data[0]))->size = size; ((SPIFlashInfo *)(&data[0]))->size = size;
@ -146,6 +149,7 @@ bool flash_rom_set_size_type(uint8_t size)
NODE_DBG("\nWRITE SUCCESS, %u\n", size); NODE_DBG("\nWRITE SUCCESS, %u\n", size);
} }
} }
free (data);
NODE_DBG("\nEND SET FLASH HEADER\n"); NODE_DBG("\nEND SET FLASH HEADER\n");
return true; return true;
} }
@ -267,7 +271,9 @@ bool flash_rom_set_speed(uint32_t speed)
// Reboot required!!! // Reboot required!!!
// If you don't know what you're doing, your nodemcu may turn into stone ... // If you don't know what you're doing, your nodemcu may turn into stone ...
NODE_DBG("\nBEGIN SET FLASH HEADER\n"); NODE_DBG("\nBEGIN SET FLASH HEADER\n");
uint8_t data[SPI_FLASH_SEC_SIZE] ICACHE_STORE_ATTR; uint8_t *data = malloc (SPI_FLASH_SEC_SIZE);
if (!data)
return false;
uint8_t speed_type = SPEED_40MHZ; uint8_t speed_type = SPEED_40MHZ;
if (speed < 26700000) if (speed < 26700000)
{ {
@ -297,6 +303,7 @@ bool flash_rom_set_speed(uint32_t speed)
NODE_DBG("\nWRITE SUCCESS, %u\n", speed_type); NODE_DBG("\nWRITE SUCCESS, %u\n", speed_type);
} }
} }
free (data);
NODE_DBG("\nEND SET FLASH HEADER\n"); NODE_DBG("\nEND SET FLASH HEADER\n");
return true; return true;
} }

View File

@ -97,7 +97,7 @@ static bool next_event (task_event_t *ev, task_prio_t *prio)
{ {
for (task_prio_t p = TASK_PRIORITY_COUNT; p != TASK_PRIORITY_LOW; --p) for (task_prio_t p = TASK_PRIORITY_COUNT; p != TASK_PRIORITY_LOW; --p)
{ {
if (xQueueReceive (task_Q[p-1], ev, 0) == pdTRUE) if (task_Q[p-1] && xQueueReceive (task_Q[p-1], ev, 0) == pdTRUE)
{ {
*prio = p-1; *prio = p-1;
return true; return true;

View File

@ -23,6 +23,7 @@
#include "task/task.h" #include "task/task.h"
#include "sections.h" #include "sections.h"
#include "mem.h" #include "mem.h"
#include "freertos/task.h"
#ifdef LUA_USE_MODULES_RTCTIME #ifdef LUA_USE_MODULES_RTCTIME
#include "rtc/rtctime.h" #include "rtc/rtctime.h"
@ -117,6 +118,18 @@ void nodemcu_init(void)
task_post_low(task_get_id(start_lua),'s'); task_post_low(task_get_id(start_lua),'s');
} }
static void nodemcu_main (void *param)
{
(void)param;
nodemcu_init ();
task_pump_messages ();
__builtin_unreachable ();
}
/****************************************************************************** /******************************************************************************
* FunctionName : user_init * FunctionName : user_init
* Description : entry of user application, init user function here * Description : entry of user application, init user function here
@ -129,14 +142,21 @@ void user_init(void)
rtctime_late_startup (); rtctime_late_startup ();
#endif #endif
#if 0
// TODO: fix uart driver to work with RTOS SDK
UartBautRate br = BIT_RATE_DEFAULT; UartBautRate br = BIT_RATE_DEFAULT;
input_sig = task_get_id(handle_input); input_sig = task_get_id(handle_input);
uart_init (br, br, input_sig); uart_init (br, br, input_sig);
#endif
#ifndef NODE_DEBUG #ifndef NODE_DEBUG
system_set_os_print(0); system_set_os_print(0);
#endif #endif
system_init_done_cb(nodemcu_init); // FIXME! Max supported RTOS stack size is 512 words (2k bytes), but
// NodeMCU currently uses more than that. The game is on to find these
// culprits, but this gcc doesn't do the -fstack-usage option :(
xTaskCreate (
nodemcu_main, "nodemcu", 600, 0, configTIMER_TASK_PRIORITY +1, NULL);
} }

View File

@ -14,7 +14,6 @@
// FIXME // FIXME
static inline void system_set_os_print(uint8 onoff) { (void)onoff; } static inline void system_set_os_print(uint8 onoff) { (void)onoff; }
static inline void system_init_done_cb(void *cb) { (void)cb; }
bool wifi_softap_deauth(uint8 mac[6]); bool wifi_softap_deauth(uint8 mac[6]);