[SOLVED] ESP8266 MySensors 2.2.0 problem with static ip configuration



  • Hi all,

    EDIT 2018/06/10: Solution:
    It seems that some old wifi settings on my ESP8266 module has conflicted with the MySensors gateway sketch. I was able to set an static ip address after an complete erase of sketch and flash through Arduino IDE. - Thanks!

    ==================================================================================

    If I try to configure my very basic (nearly plain) new ESP8266 MySensors 2.2.0 gateway with an static ip address then I get in serial monitor the following repeating output:
    (Log parser do not have further information for this specific error?)

    48 MCO:BGN:INIT GW,CP=RRNGE---,VER=2.2.0
    91 TSF:LRT:OK
    106 TSM:INIT
    119 TSF:WUR:MS=0
    139 TSM:INIT:TSP OK
    160 TSM:INIT:GW MODE
    scandone
    state: 0 -> 2 (b0)
    state: 2 -> 3 (0)
    state: 3 -> 5 (10)
    add 0
    aid 1
    cnt
    
    connected with SSID, channel 5
    dhcp client start...
    331 TSM:READY:ID=0,PAR=0,DIS=0
    364 MCO:REG:NOT NEEDED
    scandone
    889 GWT:TPC:CONNECTING...
    1416 GWT:TPC:CONNECTING...
    1944 GWT:TPC:CONNECTING...
    2472 GWT:TPC:CONNECTING...
    3000 GWT:TPC:CONNECTING...
    3528 GWT:TPC:CONNECTING...
    4056 GWT:TPC:CONNECTING...
    4584 GWT:TPC:CONNECTING...
    5112 GWT:TPC:CONNECTING...
    5640 GWT:TPC:CONNECTING...
    6168 GWT:TPC:CONNECTING...
    6696 GWT:TPC:CONNECTING...
    7224 GWT:TPC:CONNECTING...
    7752 GWT:TPC:CONNECTING...
    8280 GWT:TPC:CONNECTING...
    

    If I switch to dhcp then everything is working like expected.
    And of course the ip is not already assigned by an different device 😉

    What I am doing wrong?

    ␀�/��␝���48 MCO:BGN:INIT GW,CP=RRNGE---,VER=2.2.0
    91 TSF:LRT:OK
    105 TSM:INIT
    119 TSF:WUR:MS=0
    139 TSM:INIT:TSP OK
    160 TSM:INIT:GW MODE
    scandone
    state: 0 -> 2 (b0)
    state: 2 -> 3 (0)
    state: 3 -> 5 (10)
    add 0
    aid 1
    cnt
    
    connected with SSID channel 5
    dhcp client start...
    331 TSM:READY:ID=0,PAR=0,DIS=0
    363 MCO:REG:NOT NEEDED
    scandone
    889 GWT:TPC:CONNECTING...
    1416 GWT:TPC:CONNECTING...
    1944 GWT:TPC:CONNECTING...
    2472 GWT:TPC:CONNECTING...
    3000 GWT:TPC:CONNECTING...
    ip:10.0.8.160,mask:255.255.255.0,gw:10.0.8.253
    3528 GWT:TPC:CONNECTING...
    3556 GWT:TPC:IP=10.0.8.160
    3584 MCO:BGN:STP
    
    -- STA (client) informations --
    Hostname: mqtt-sensor-gateway1
    Connected to: SSID (xx:xx:xx:xx:xx:xx), -45dBm
    IP address: 10.0.8.160
    Gateway address: 10.0.8.253
    Subnet mask: 255.255.255.0
    MAC STA address: xx:xx:xx:xx:xx:xx
    -- AP (server) informations --
    Soft IP address: 0.0.0.0
    MAC AP address: xx:xx:xx:xx:xx:xx
    ----
    
    3826 MCO:BGN:INIT OK,TSP=1
    3986 GWT:TPC:IP=10.0.8.160
    4014 GWT:RMQ:MQTT RECONNECT
    4058 GWT:RMQ:MQTT CONNECTED
    4087 GWT:TPS:TOPIC=ehome/gateway1-out/0/255/0/0/18,MSG SENT
    pm open,type:2 0
    

    Sketch:

    /**
     * The MySensors Arduino library handles the wireless radio link and protocol
     * between your home built sensors/actuators and HA controller of choice.
     * The sensors forms a self healing radio network with optional repeaters. Each
     * repeater and gateway builds a routing tables in EEPROM which keeps track of the
     * network topology allowing messages to be routed to nodes.
     *
     * Created by Henrik Ekblad <henrik.ekblad@mysensors.org>
     * Copyright (C) 2013-2015 Sensnology AB
     * Full contributor list: https://github.com/mysensors/Arduino/graphs/contributors
     *
     * Documentation: http://www.mysensors.org
     * Support Forum: http://forum.mysensors.org
     *
     * This program is free software; you can redistribute it and/or
     * modify it under the terms of the GNU General Public License
     * version 2 as published by the Free Software Foundation.
     *
     *******************************
     *
     * REVISION HISTORY
     * Version 1.0 - Henrik Ekblad
     *
     * DESCRIPTION
     * The ESP8266 MQTT gateway sends radio network (or locally attached sensors) data to your MQTT broker.
     * The node also listens to MY_MQTT_TOPIC_PREFIX and sends out those messages to the radio network
     *
     * LED purposes:
     * - To use the feature, uncomment any of the MY_DEFAULT_xx_LED_PINs in your sketch
     * - RX (green) - blink fast on radio message recieved. In inclusion mode will blink fast only on presentation recieved
     * - TX (yellow) - blink fast on radio message transmitted. In inclusion mode will blink slowly
     * - ERR (red) - fast blink on error during transmission error or recieve crc error
     *
     * See http://www.mysensors.org/build/esp8266_gateway for wiring instructions.
     * nRF24L01+  ESP8266
     * VCC        VCC
     * CE         GPIO4
     * CSN/CS     GPIO15
     * SCK        GPIO14
     * MISO       GPIO12
     * MOSI       GPIO13
     *
     * Not all ESP8266 modules have all pins available on their external interface.
     * This code has been tested on an ESP-12 module.
     * The ESP8266 requires a certain pin configuration to download code, and another one to run code:
     * - Connect REST (reset) via 10K pullup resistor to VCC, and via switch to GND ('reset switch')
     * - Connect GPIO15 via 10K pulldown resistor to GND
     * - Connect CH_PD via 10K resistor to VCC
     * - Connect GPIO2 via 10K resistor to VCC
     * - Connect GPIO0 via 10K resistor to VCC, and via switch to GND ('bootload switch')
     *
      * Inclusion mode button:
     * - Connect GPIO5 via switch to GND ('inclusion switch')
     *
     * Hardware SHA204 signing is currently not supported!
     *
     * Make sure to fill in your ssid and WiFi password below for ssid & pass.
     */
    
    // Enable debug prints to serial monitor
    #define MY_DEBUG
    
    // Use a bit lower baudrate for serial prints on ESP8266 than default in MyConfig.h
    #define MY_BAUD_RATE 9600
    
    // Enables and select radio type (if attached)
    //#define MY_RADIO_NRF24
    //#define MY_RADIO_RFM69
    //#define MY_RADIO_RFM95
    
    #define MY_RADIO_RFM69
    #define MY_RFM69_FREQUENCY RFM69_433MHZ // Set your frequency here
    //#define MY_IS_RFM69HW // Omit if your RFM is not "H"
    #define MY_RF69_IRQ_PIN D1
    #define MY_RF69_IRQ_NUM MY_RF69_IRQ_PIN
    #define MY_RFM69_CS_PIN D8 // NSS. Use MY_RF69_SPI_CS for older versions (before 2.2.0)
    
    #define MY_RFM69_NETWORKID 200 // Default is 100 in lib. Uncomment it and set your preferred network id if needed
    
    #define MY_GATEWAY_MQTT_CLIENT
    #define MY_GATEWAY_ESP8266
    
    // Set this node's subscribe and publish topic prefix
    #define MY_MQTT_PUBLISH_TOPIC_PREFIX "ehome/gateway1-out"
    #define MY_MQTT_SUBSCRIBE_TOPIC_PREFIX "ehome/gateway1-in"
    
    // Set MQTT client id
    #define MY_MQTT_CLIENT_ID "ehome-gw-1"
    
    // Set WIFI SSID and password
    #define MY_ESP8266_SSID "MySSID"
    #define MY_ESP8266_PASSWORD "MyPassword"
    
    // Set the hostname for the WiFi Client. This is the hostname
    // it will pass to the DHCP server if not static.
    #define MY_ESP8266_HOSTNAME "mqtt-sensor-gateway1"
    
    // Enable MY_IP_ADDRESS here if you want a static ip address (no DHCP)
    #define MY_IP_ADDRESS 10, 0, 8, 200
    
    // If using static ip you can define Gateway and Subnet address as well
    #define MY_IP_GATEWAY_ADDRESS 10, 0, 8, 253
    #define MY_IP_SUBNET_ADDRESS 255, 255, 255, 0
    
    // MQTT broker ip address.
    #define MY_CONTROLLER_IP_ADDRESS 10, 0, 12, 200
    
    // Enable these if your MQTT broker requires username/password
    #define MY_MQTT_USER "MyUsername"
    #define MY_MQTT_PASSWORD "MyPassword"
    
    // The MQTT broker port to to open
    #define MY_PORT 1883
    
    // Enable inclusion mode
    //#define MY_INCLUSION_MODE_FEATURE
    // Enable Inclusion mode button on gateway
    //#define MY_INCLUSION_BUTTON_FEATURE
    // Set inclusion mode duration (in seconds)
    //#define MY_INCLUSION_MODE_DURATION 60
    // Digital pin used for inclusion mode button
    //#define MY_INCLUSION_MODE_BUTTON_PIN  3
    
    // Set blinking period
    //#define MY_DEFAULT_LED_BLINK_PERIOD 300
    
    // Flash leds on rx/tx/err
    //#define MY_DEFAULT_ERR_LED_PIN 16  // Error led pin
    //#define MY_DEFAULT_RX_LED_PIN  16  // Receive led pin
    //#define MY_DEFAULT_TX_LED_PIN  16  // the PCB, on board LED
    
    #include <ESP8266WiFi.h>
    #include <ArduinoOTA.h>
    #include <MySensors.h>
    
    void setup()
    {
      // Setup locally attached sensors
    #if defined MY_DEBUG
      if (WiFi.status() != WL_CONNECTED)
      {
        Serial.println("Not connected to WiFi");
      }
      else
      {
        Serial.println("");
        Serial.println("-- STA (client) informations --");
        Serial.print("Hostname: ");
        Serial.println(WiFi.hostname());
        Serial.print("Connected to: ");
        Serial.print(WiFi.SSID());
        Serial.print(" (");
        Serial.print(WiFi.BSSIDstr());
        Serial.print("), ");
        Serial.print(WiFi.RSSI());
        Serial.println("dBm");
        Serial.print("IP address: ");
        Serial.println(WiFi.localIP());
        Serial.print("Gateway address: ");
        Serial.println(WiFi.gatewayIP());
        Serial.print("Subnet mask: ");
        Serial.println(WiFi.subnetMask());
        Serial.print("MAC STA address: ");
        Serial.println(WiFi.macAddress());
        Serial.println("-- AP (server) informations --");
        Serial.print("Soft IP address: ");
        Serial.println(WiFi.softAPIP());
        Serial.print("MAC AP address: ");
        Serial.println(WiFi.softAPmacAddress());
        Serial.println("----");
        Serial.println("");
      }
    #endif
      ArduinoOTA.onStart([]() {
        Serial.println("ArduinoOTA start");
      });
      ArduinoOTA.onEnd([]() {
        Serial.println("\nArduinoOTA end");
      });
      ArduinoOTA.onProgress([](unsigned int progress, unsigned int total) {
        Serial.printf("OTA Progress: %u%%\r", (progress / (total / 100)));
      });
      ArduinoOTA.onError([](ota_error_t error) {
        Serial.printf("Error[%u]: ", error);
        if (error == OTA_AUTH_ERROR)
        {
          Serial.println("Auth Failed");
        }
        else if (error == OTA_BEGIN_ERROR)
        {
          Serial.println("Begin Failed");
        }
        else if (error == OTA_CONNECT_ERROR)
        {
          Serial.println("Connect Failed");
        }
        else if (error == OTA_RECEIVE_ERROR)
        {
          Serial.println("Receive Failed");
        }
        else if (error == OTA_END_ERROR)
        {
          Serial.println("End Failed");
        }
      });
      ArduinoOTA.begin();
    }
    
    void presentation()
    {
      // Present locally attached sensors here
    }
    
    void loop()
    {
      // Send locally attech sensors data here
      ArduinoOTA.handle();
    }
    
    

Log in to reply
 

Suggested Topics

  • 1
  • 1
  • 3
  • 2
  • 1
  • 6

62
Online

11.4k
Users

11.1k
Topics

112.7k
Posts