[SOLVED] Sensbender Gateway gives a lot of "hu"



  • I'm trying to revive my MySensors network, and started by flasking a new GatewaySerial to the Sensbender Gateway. I have the NRF24 long range version connected to it.

    When the sketch starts this is what I get and it looks wrong to me. A lot of "hu".
    I have cleared eeprom, but still the same. I ave not changed anything, it is stock 2.3.1 and stock GatewaySerial.

    Any idea what I should try next?

    0;255;hu;0;hu;3 MCO:BGN:INIT GW,CP=RNNGS---,REL=hu,VER=2.3.1
    0;255;hu;0;hu;3 TSF:LRT:OK
    0;255;hu;0;hu;3 TSM:INIT
    0;255;hu;0;hu;3 TSF:WUR:MS=0
    0;255;hu;0;hu;3 TSM:INIT:TSP OK
    0;255;hu;0;hu;3 TSM:INIT:GW MODE
    0;255;hu;0;hu;3 TSM:READY:ID=hu,PAR=hu,DIS=hu
    0;255;hu;0;hu;3 MCO:REG:NOT NEEDED
    hu;hu;hu;hu;hu;�
    hu;hu;hu;hu;hu;�
    0;255;hu;0;hu;3 MCO:BGN:STP
    0;255;hu;0;hu;3 MCO:BGN:INIT OK,TSP=hu
    0;255;hu;0;hu;3 TSM:READY:NWD REQ
    0;255;hu;0;hu;3 TSF:MSG:SEND,hu-hu-hu-hu,s=hu,c=hu,t=hu,pt=hu,l=hu,sg=hu,ft=hu,st=�:�```

  • Admin

    @magpern This originates from the updated Arduino SAMD board definitions (>1.8.1) and is fixed in the dev branch. You can add

    #undef PRId8
    #undef PRIi8
    #undef PRIo8
    #undef PRIu8
    #undef PRIx8
    #undef PRIX8
    #undef PRIdLEAST8
    #undef PRIiLEAST8
    #undef PRIoLEAST8
    #undef PRIuLEAST8
    #undef PRIxLEAST8
    #undef PRIXLEAST8
    #undef PRIdFAST8
    #undef PRIiFAST8
    #undef PRIoFAST8
    #undef PRIuFAST8
    #undef PRIxFAST8
    #undef PRIXFAST8
    #define PRId8		"d"
    #define PRIi8		"i"
    #define PRIo8		"o"
    #define PRIu8		"u"
    #define PRIx8		"x"
    #define PRIX8		"X"
    #define PRIdLEAST8	"d"
    #define PRIiLEAST8	"i"
    #define PRIoLEAST8	"o"
    #define PRIuLEAST8	"u"
    #define PRIxLEAST8	"x"
    #define PRIXLEAST8	"X"
    #define PRIdFAST8	"d"
    #define PRIiFAST8	"i"
    #define PRIoFAST8	"o"
    #define PRIuFAST8	"u"
    #define PRIxFAST8	"x"
    #define PRIXFAST8	"X"
    

    before the MySensor.h include to temporarily fix that.



  • @tekka Thanks! Development branch worked



  • @tekka said in [SOLVED] Sensbender Gateway gives a lot of "hu":

    This originates from the updated Arduino SAMD board definitions (>1.8.1) and is fixed in the dev branch. You can add

    Hi
    I have a problem. I buy Sensbender Gateway and compile it with radio RFM69HW and write.... This is my 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-2019 Sensnology AB
    * Full contributor list: https://github.com/mysensors/MySensors/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.
    *
    *******************************
    *
    * DESCRIPTION
    * The ArduinoGateway prints data received from sensors on the serial link.
    * The gateway accepts input on serial which will be sent out on radio network.
    *
    * This GW code is designed for Sensebender GateWay / (Arduino Zero variant)
    *
    * Wire connections (OPTIONAL):
    * - Inclusion button should be connected to SW2
    *
    * LEDs on board (default assignments):
    * - Orange: USB RX/TX - Blink when receiving / transmitting on USB CDC device
    * - Yellow: RX  - Blink fast on radio message received. In inclusion mode will blink fast only on presentation received
    * - Green : TX  - Blink fast on radio message transmitted. In inclusion mode will blink slowly
    * - Red   : ERR - Fast blink on error during transmission error or receive crc error
    * - Blue  : free - (use with LED_BLUE macro)
    *
    */
    
    #define SKETCH_VERSION "0.2"
    // Enable debug prints to serial monitor
    #define MY_DEBUG
    
    // Enable and select radio type attached
    //#define MY_RADIO_RF24
    //#define MY_RADIO_NRF5_ESB
    //#define MY_RADIO_RFM69
    //#define MY_RADIO_RFM95
    #define MY_RADIO_RFM69
    #define MY_IS_RFM69HW
    #define RFM69_868MH
    #define MY_RFM69_NEW_DRIVER
    
    // Set LOW transmit power level as default, if you have an amplified NRF-module and
    // power your radio separately with a good regulator you can turn up PA level.
    //#define MY_RF24_PA_LEVEL RF24_PA_HIGH
    
    // Enable serial gateway
    #define MY_GATEWAY_SERIAL
    
    // Define a lower baud rate for Arduinos running on 8 MHz (Arduino Pro Mini 3.3V & Sensebender)
    #if F_CPU == 8000000L
    #define MY_BAUD_RATE 38400
    #endif
    
    // Enable inclusion mode
    #define MY_INCLUSION_MODE_FEATURE
    // Enable Inclusion mode button on gateway
    #define MY_INCLUSION_BUTTON_FEATURE
    
    // Inverses behavior of inclusion button (if using external pullup)
    //#define MY_INCLUSION_BUTTON_EXTERNAL_PULLUP
    
    // 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
    
    // Inverses the behavior of leds
    //#define MY_WITH_LEDS_BLINKING_INVERSE
    
    // Flash leds on rx/tx/err
    // Uncomment to override default HW configurations
    //#define MY_DEFAULT_ERR_LED_PIN 4  // Error led pin
    //#define MY_DEFAULT_RX_LED_PIN  6  // Receive led pin
    //#define MY_DEFAULT_TX_LED_PIN  5  // the PCB, on board LED
    
    #include <MySensors.h>
    #include <SD.h>
    #include <drivers/ATSHA204/ATSHA204.cpp>
    
    Sd2Card card;
    
    #define EEPROM_VERIFICATION_ADDRESS 0x01
    
    static uint8_t num_of_leds = 5;
    static uint8_t leds[] = {LED_BLUE, LED_RED, LED_GREEN, LED_YELLOW, LED_ORANGE};
    
    void setup()
    {
    	// Setup locally attached sensors
    }
    
    void presentation()
    {
    	// Present locally attached sensors
    }
    
    void loop()
    {
    	// Send locally attached sensor data here
    }
    
    
    void preHwInit()
    {
    
    	pinMode(MY_SWC1, INPUT_PULLUP);
    	pinMode(MY_SWC2, INPUT_PULLUP);
    	if (digitalRead(MY_SWC1) && digitalRead(MY_SWC2)) {
    		return;
    	}
    
    	uint8_t tests = 0;
    
    	for (int i=0; i< num_of_leds; i++) {
    		pinMode(leds[i], OUTPUT);
    	}
    	if (digitalRead(MY_SWC1)) {
    		uint8_t led_state = 0;
    		while (!Serial) {
    			digitalWrite(LED_BLUE, led_state);
    			led_state ^= 0x01;
    			delay(500);
    		} // Wait for USB to be connected, before spewing out data.
    	}
    	if (Serial) {
    		Serial.println("Sensebender GateWay test routine");
    		Serial.print("MySensors core version : ");
    		Serial.println(MYSENSORS_LIBRARY_VERSION);
    		Serial.print("GateWay sketch version : ");
    		Serial.println(SKETCH_VERSION);
    		Serial.println("----------------------------------");
    		Serial.println();
    	}
    	if (testSha204()) {
    		digitalWrite(LED_GREEN, HIGH);
    		tests++;
    	}
    	if (testSDCard()) {
    		digitalWrite(LED_YELLOW, HIGH);
    		tests++;
    	}
    
    	if (testEEProm()) {
    		digitalWrite(LED_ORANGE, HIGH);
    		tests++;
    	}
    	if (tests == 4) {
    		while(1) {
    			for (int i=0; i<num_of_leds; i++) {
    				digitalWrite(leds[i], HIGH);
    				delay(200);
    				digitalWrite(leds[i], LOW);
    			}
    		}
    	} else {
    		while (1) {
    			digitalWrite(LED_RED, HIGH);
    			delay(200);
    			digitalWrite(LED_RED, LOW);
    			delay(200);
    		}
    	}
    
    }
    
    bool testSha204()
    {
    	uint8_t rx_buffer[SHA204_RSP_SIZE_MAX];
    	uint8_t ret_code;
    	if (Serial) {
    		Serial.print("- > SHA204 ");
    	}
    	atsha204_init(MY_SIGNING_ATSHA204_PIN);
    	ret_code = atsha204_wakeup(rx_buffer);
    
    	if (ret_code == SHA204_SUCCESS) {
    		ret_code = atsha204_getSerialNumber(rx_buffer);
    		if (ret_code != SHA204_SUCCESS) {
    			if (Serial) {
    				Serial.println(F("Failed to obtain device serial number. Response: "));
    			}
    			Serial.println(ret_code, HEX);
    		} else {
    			if (Serial) {
    				Serial.print(F("Ok (serial : "));
    				for (int i=0; i<9; i++) {
    					if (rx_buffer[i] < 0x10) {
    						Serial.print('0'); // Because Serial.print does not 0-pad HEX
    					}
    					Serial.print(rx_buffer[i], HEX);
    				}
    				Serial.println(")");
    			}
    			return true;
    		}
    	} else {
    		if (Serial) {
    			Serial.println(F("Failed to wakeup SHA204"));
    		}
    	}
    	return false;
    }
    
    bool testSDCard()
    {
    	if (Serial) {
    		Serial.print("- > SD CARD ");
    	}
    	if (!card.init(SPI_HALF_SPEED, MY_SDCARD_CS)) {
    		if (Serial) {
    			Serial.println("SD CARD did not initialize!");
    		}
    	} else {
    		if (Serial) {
    			Serial.print("SD Card initialized correct! - ");
    			Serial.print("type detected : ");
    			switch(card.type()) {
    			case SD_CARD_TYPE_SD1:
    				Serial.println("SD1");
    				break;
    			case SD_CARD_TYPE_SD2:
    				Serial.println("SD2");
    				break;
    			case SD_CARD_TYPE_SDHC:
    				Serial.println("SDHC");
    				break;
    			default:
    				Serial.println("Unknown");
    			}
    		}
    		return true;
    	}
    	return false;
    }
    
    bool testEEProm()
    {
    	uint8_t eeprom_d1, eeprom_d2;
    	SerialUSB.print(" -> EEPROM ");
    	eeprom_d1 = hwReadConfig(EEPROM_VERIFICATION_ADDRESS);
    	delay(500);
    	eeprom_d1 = ~eeprom_d1; // invert the bits
    	hwWriteConfig(EEPROM_VERIFICATION_ADDRESS, eeprom_d1);
    	delay(500);
    	eeprom_d2 = hwReadConfig(EEPROM_VERIFICATION_ADDRESS);
    	if (eeprom_d1 == eeprom_d2) {
    		SerialUSB.println("PASSED");
    		hwWriteConfig(EEPROM_VERIFICATION_ADDRESS, ~eeprom_d1);
    		return true;
    	}
    	SerialUSB.println("FAILED!");
    	return false;
    }
    
    bool testAnalog()
    {
    	int bat_detect = analogRead(MY_BAT_DETECT);
    	Serial.print("-> analog : ");
    	Serial.print(bat_detect);
    	if (bat_detect < 400 || bat_detect > 650) {
    		Serial.println(" Failed");
    		return false;
    	}
    	Serial.println(" Passed");
    	return true;
    }```
    

    On serial port monitor show me this:

    0;255;hu;0;hu;3 MCO:BGN:INIT GW,CP=RPNGS---,VER=2.2.0
    0;255;hu;0;hu;3 TSF:LRT:OK
    0;255;hu;0;hu;3 TSM:INIT
    0;255;hu;0;hu;3 TSF:WUR:MS=0
    0;255;hu;0;hu;3 TSM:INIT:TSP OK
    0;255;hu;0;hu;3 TSM:INIT:GW MODE
    0;255;hu;0;hu;3 TSM:READY:ID=hu,PAR=hu,DIS=hu
    0;255;hu;0;hu;3 MCO:REG:NOT NEEDED
    hu;hu;hu;hu;hu;⸮
    hu;hu;hu;hu;hu;⸮
    0;255;hu;0;hu;3 MCO:BGN:STP
    0;255;hu;0;hu;3 MCO:BGN:INIT OK,TSP=hu
    

    I connect it to my raspberry pi 4 with Hass.io image 3.3. Then in configuration add it:

    mysensors:
    gateways:
    - device: '/dev/ttyACM0'
    persistence_file: '/config/mysensors.json'
    baud_rate: 38400
    optimistic: false
    persistence: true
    version: '2.2'
    

    and still in log has info:

    Gateway /dev/ttyACM0 not ready after 15.0 secs so continuing with setup
    20:56 components/mysensors/gateway.py (WARNING)
    

    In hardware on hassio show this:
    /dev/ttyACM0
    /dev/serial/by-id/usb-MySensors.org_Sensebender_GW_6A153443514D355934202020FF10182D-if00
    /dev/ttyAMA0

    Please help me what i do wrong...and how resolved this problem.



  • @pepson said in [SOLVED] Sensbender Gateway gives a lot of "hu":

    Please help me what i do wrong...and how resolved this problem.

    It is the exact same problem as I had. Do what @tekka said. Either put in the code he suggested, or git clone the development branch. The development branch works fine, the "hu" will go away

    And if git clone is to difficult. Download the dev branch github as zip, unzip it and replace the entire "MySensors" folder on your computer. Exactly where it is, I don't know. It's in the library folder where Arduino is installed



  • @magpern
    But mysensors newer than 2.2.0 has problems with radio Rfm69hw.



  • @pepson said in [SOLVED] Sensbender Gateway gives a lot of "hu":

    @magpern
    But mysensors newer than 2.2.0 has problems with radio Rfm69hw.

    That I don't know anything about. I don't have any Rfm69w for the moment, but I know I ran a rfm69 directly of a raspberry pi about 5 month ago ant that worked fine. And that was the development branch, so more than 2.2.0


Log in to reply
 

Suggested Topics

13
Online

11.4k
Users

11.1k
Topics

112.7k
Posts