添加不相关的代码后,SPIFSS代码崩溃

时间:2016-09-28 08:10:41

标签: arduino filesystems esp8266 arduino-esp8266 spiffs

我遇到了一种奇怪的行为。我使用ESP8266 arduino SPIFFS来存储配置设置。这是mycode的相关部分;

void loop()
{
      handleUartRxOk();
}

void handleUartRxOk() {
    String cmd;

    char charBuff[3200];
    char char_print[50];
    static bool terminatorReceived = false;

    char incomingChar = 0;   // for incoming serial data

    if (Serial.available()) {
        incomingChar = Serial.read();
        saveChar(incomingChar);

        if (incomingChar == '\r') {
            terminatorReceived = true;
        }

        if (terminatorReceived) {
            buffer[buffer_index - 1] = '\0';
            cmd = String(buffer);
            if (cmd == "XXX") {
                ConfigSettings.ssid = "SSID_XX";
                ConfigSettings.password = "PASSWORD_XX";
                saveConfig();
            } 

            buffer_index = 0;
            terminatorReceived = false;
        }
    }
}

在上面的代码中,UART将收到一个命令“XXX \ r \ n”,然后运行saveConfig(),它将配置参数ssid和参数保存到SPIFSS中。此代码完全正常,直到我添加更多完全不相关的代码。

这就是新代码的样子。

void handleUartRxOk() {
    String cmd;

    char charBuff[3200];
    char char_print[50];
    static bool terminatorReceived = false;

    char incomingChar = 0;   // for incoming serial data

    if (Serial.available()) {
        incomingChar = Serial.read();
        saveChar(incomingChar);

        if (incomingChar == '\r') {
            terminatorReceived = true;
        }

        if (terminatorReceived) {
            buffer[buffer_index - 1] = '\0';
            cmd = String(buffer);
            if (cmd == "XXX") {
                ConfigSettings.ssid = "SSID_XX";
                ConfigSettings.password = "PASSWORD_XX";
                saveConfig();
            } 

            //Why does adding this else statement cause saveConfig() to crash when run?
            else {
                    strcat(charBuff, cmd.c_str());
                }   

            buffer_index = 0;
            terminatorReceived = false;
        }
    }
}

添加其他else子句后,向UARt发送“XXX \ r”并导致saveConfig()将导致异常错误。这令人费解,因为新代码甚至无法运行。

异常错误如下;

Exception (3):

epc1=0x401002f0 epc2=0x00000000 epc3=0x00000000 excvaddr=0x400072f6 depc=0x00000
000

ctx: sys 

sp: 3fff06b0 end: 3fffffb0 offset: 01a0

1 个答案:

答案 0 :(得分:2)

char charBuff[3200];声明为全局而不是函数内部。 Arduino ESP8266的默认堆栈大小约为4k。您的阵列大小有溢出的风险。试一试,看看它是否有效。我之前遇到过类似的问题。它对我有用。

通过修改cores / esp8266 /

下的cont.h,可以在内存限制内提高默认堆栈大小

编辑:Daniel Minion在评论中提供了有关修改默认堆栈大小的信息。