Connecting to MQTT error
Posted: Sat Jun 24, 2017 10:47 am
Hi all,
I'm trying to flash a Sonoff Switch, the error I'm getting is
My main code is
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
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