So you're a Noob? Post your questions here until you graduate! Don't be shy.

User avatar
By Frostmaul
#67536 Hi all,

I'm trying to flash a Sonoff Switch, the error I'm getting is

Code: Select all⸮..
WiFi connected
IP address:
192.168.0.4
Connecting to MQTT...
Exception (3):
epc1=0x4000c14c epc2=0x00000000 epc3=0x00000000 excvaddr=0x402303d0 depc=0x00000000

ctx: cont
sp: 3ffef560 end: 3ffef7a0 offset: 01a0

>>>stack>>>
3ffef700:  3ffee58a 3ffee568 3ffee58c 40203cbc 
3ffef710:  402303c0 00000001 3ffee58f 00001770 
3ffef720:  3ffee4d1 00000000 3ffee58a 40203015 
3ffef730:  00000003 3ffee58a 3ffee568 402030cc 
3ffef740:  3ffee57c 3ffee654 3ffee744 402034e0 
3ffef750:  0400a8c0 00ffffff 3ffee744 3ffee770 
3ffef760:  00000003 3ffee568 3ffee744 40201eea 
3ffef770:  3fffdad0 00000000 3ffee768 40201f1c 
3ffef780:  3fffdad0 00000000 3ffee768 40203950 
3ffef790:  feefeffe feefeffe 3ffee780 40100718 
<<<stack<<<

 ets Jan  8 2013,rst cause:4, boot mode:(1,6)

wdt reset

 ets Jan  8 2013,rst cause:4, boot mode:(1,6)

wdt reset


My main code is
Code: Select all/***************************************************
  Adafruit MQTT Library ESP8266 Example
  Must use ESP8266 Arduino from:
    https://github.com/esp8266/Arduino
  Works great with Adafruit's Huzzah ESP board & Feather
  ----> https://www.adafruit.com/product/2471
  ----> https://www.adafruit.com/products/2821
  Adafruit invests time and resources providing this open source code,
  please support Adafruit and open-source hardware by purchasing
  products from Adafruit!
  Written by Tony DiCola for Adafruit Industries.
  MIT license, all text above must be included in any redistribution
 ****************************************************/


#include <ESP8266WiFi.h>
#include "Adafruit_MQTT.h"
#include "Adafruit_MQTT_Client.h"

/************************* WiFi Access Point *********************************/

#define WLAN_SSID       "WIFI_ID_REMOVED"
#define WLAN_PASS       "WIFI_ID_REMOVED"

/************************* Adafruit.io Setup *********************************/

#define AIO_SERVER      "io.adafruit.com"
#define AIO_SERVERPORT  1883                   // use 8883 for SSL
#define AIO_USERNAME    "ID_REMOVED"
#define AIO_KEY         "ID_REMOVED"

/************ Global State (you don't need to change this!) ******************/

// Create an ESP8266 WiFiClient class to connect to the MQTT server.
WiFiClient client;
// or... use WiFiFlientSecure for SSL
//WiFiClientSecure client;

// Store the MQTT server, username, and password in flash memory.
// This is required for using the Adafruit MQTT library.
//const char MQTT_SERVER[] PROGMEM    = AIO_SERVER;
//const char MQTT_USERNAME[] PROGMEM  = AIO_USERNAME;
//const char MQTT_PASSWORD[] PROGMEM  = AIO_KEY;

// Setup the MQTT client class by passing in the WiFi client and MQTT server and login details.
Adafruit_MQTT_Client mqtt(&client, AIO_SERVER, AIO_SERVERPORT, AIO_USERNAME, AIO_KEY);

/****************************** Feeds ***************************************/

// Setup a feed called 'onoff' for subscribing to changes.
const char ONOFF_FEED[] PROGMEM = AIO_USERNAME "/feeds/onoff";
Adafruit_MQTT_Subscribe onoffbutton = Adafruit_MQTT_Subscribe(&mqtt, ONOFF_FEED);
Adafruit_MQTT_Publish onOff = Adafruit_MQTT_Publish(&mqtt, ONOFF_FEED);//Manual switch

/*************************** Sketch Code ************************************/

// Bug workaround for Arduino 1.6.6, it seems to need a function declaration
// for some reason (only affects ESP8266, likely an arduino-builder bug).
void MQTT_connect();

#define RELAY 12
#define LED 13
#define SWITCH 0

boolean toggle = false;

void setup() {
  Serial.begin(115200);
  delay(10);
  pinMode(RELAY, OUTPUT);
  pinMode(LED, OUTPUT);
  digitalWrite(LED, HIGH);
  pinMode(SWITCH, INPUT_PULLUP);

  Serial.println(F("Adafruit MQTT SONOFF Demo"));

  // Connect to WiFi access point.
  Serial.println(); Serial.println();
  Serial.print("Connecting to ");
  Serial.println(WLAN_SSID);

  WiFi.begin(WLAN_SSID, WLAN_PASS);
  while (WiFi.status() != WL_CONNECTED) {
    delay(500);
    Serial.print(".");
    toggle = !toggle;
    digitalWrite(LED, toggle);
  }
  Serial.println();

  Serial.println("WiFi connected");
  Serial.println("IP address: "); Serial.println(WiFi.localIP());
  digitalWrite(LED, HIGH);
  // Setup MQTT subscription for onoff feed.
  mqtt.subscribe(&onoffbutton);
}

uint32_t x=0;

uint8_t lastStateSwitch = 0;

void relay(char* onof){
  String state = String(onof);
  if((digitalRead(RELAY) != HIGH) && (state == "ON")){
    digitalWrite(RELAY, HIGH);//On relay
    digitalWrite(LED, LOW);//On led
  }else if((digitalRead(RELAY) == HIGH) && (state == "OFF")){
    digitalWrite(RELAY, LOW);//Off relay
    digitalWrite(LED, HIGH);//Off led
  }else{
    Serial.print("I got this = ");
    Serial.println(onof);
  }
}//end relay

void manualRelay(){
  if(!digitalRead(SWITCH)){
    lastStateSwitch = !lastStateSwitch;//Update switch state
    if(lastStateSwitch){
      if (! onOff.publish("ON")) {
        Serial.println(F("Failed"));
      } else {
        Serial.println(F("OK!"));
      }//end if
    }else{
      if (! onOff.publish("OFF")) {
        Serial.println(F("Failed"));
      } else {
        Serial.println(F("OK!"));
      }//end if   
    }//end if
  }//end if
}//end manualRelay

void loop() {
  // Ensure the connection to the MQTT server is alive (this will make the first
  // connection and automatically reconnect when disconnected).  See the MQTT_connect
  // function definition further below.
  MQTT_connect();

  // this is our 'wait for incoming subscription packets' busy subloop
  // try to spend your time here

  Adafruit_MQTT_Subscribe *subscription;
  while ((subscription = mqtt.readSubscription(5000))) {
    if (subscription == &onoffbutton) {
      Serial.print(F("Got: "));
      Serial.println((char *)onoffbutton.lastread);
      relay((char *)onoffbutton.lastread);
    }
  }

  manualRelay();

  // Now we can publish stuff!


  // ping the server to keep the mqtt connection alive
  // NOT required if you are publishing once every KEEPALIVE seconds
  /*
  if(! mqtt.ping()) {
    mqtt.disconnect();
  }
  */
}



// Function to connect and reconnect as necessary to the MQTT server.
// Should be called in the loop function and it will take care if connecting.
void MQTT_connect() {
  int8_t ret;

  // Stop if already connected.
  if (mqtt.connected()) {
    return;
  }

  Serial.print("Connecting to MQTT... ");

  uint8_t retries = 3;
  while ((ret = mqtt.connect()) != 0) { // connect will return 0 for connected
       Serial.println(mqtt.connectErrorString(ret));
       Serial.println("Retrying MQTT connection in 5 seconds...");
       mqtt.disconnect();
       delay(5000);  // wait 5 seconds
       retries--;
       if (retries == 0) {
         // basically die and wait for WDT to reset me
         while (1);
       }
  }
  Serial.println("MQTT Connected!");
}


I've come across https://forums.adafruit.com/viewtopic.php?f=19&t=102241 but no joy still :(

Any help for this noob would be much appreciated