Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Command "Dimmer 100" breaks H801 device #1146

Closed
dimitrystd opened this issue Nov 7, 2017 · 12 comments
Closed

Command "Dimmer 100" breaks H801 device #1146

dimitrystd opened this issue Nov 7, 2017 · 12 comments
Labels
enhancement Type - Enhancement that will be worked on fixed Result - The work on the issue has ended

Comments

@dimitrystd
Copy link

Maybe it's related to #1133
Spent a couple days to understand why H801 hangs from time to time.

  • Use v5.9.0a
  • Added my custom configuration user_config_override.h to /sonoff folder
  • Compiled and flashed my H801
  • Run SetOption15 1 in console and waited for restart
  • Send via mqtt cmnd/h801_bedroom/Dimmer 5. Everything looks good
  • Send again 100 via mqtt cmnd/h801_bedroom/Dimmer 100

Device starts to restart in infinite loop. It doesn't connect to wifi so i canno open console. In serial i see only


 ets Jan  8 2013,rst cause:4, boot mode:(3,7)

wdt reset
load 0x4010f000, len 1384, room 16
tail 8
chksum 0x2d
csum 0x2d
v09826c6d
~ld

 ets Jan  8 2013,rst cause:4, boot mode:(3,7)

wdt reset
load 0x4010f000, len 1384, room 16
tail 8
chksum 0x2d
csum 0x2d
v09826c6d
~ld
....

Turn off then on doesn't help. I have to flash device with blank image and then flash with firmware.

@dimitrystd
Copy link
Author

If run command in console

10:12:49 CMD: Dimmer 100
10:12:49 MQT: stat/h801_bedroom/RESULT = {"POWER":"ON", "Dimmer":100, "Color":"FFFFFF"}

Then it just restart once

10:13:06 MQT: tele/h801_bedroom/INFO3 = {"RestartReason":"Hardware Watchdog"}

So you should use mqtt for reproducing.

@dimitrystd
Copy link
Author

Hmm, repeated test with console, namely

speed 3
fade on
dimmer 100

and now it's died again.

@arendst
Copy link
Owner

arendst commented Nov 7, 2017

What is your PWMfrequency and PWMRange?

@dimitrystd
Copy link
Author

10:37:02 CMD: PWMfrequency
10:37:02 MQT: stat/h801_bedroom/RESULT = {"PWMFrequency":880}
10:37:10 CMD: PWMRange
10:37:10 MQT: stat/h801_bedroom/RESULT = {"PWMRange":1023}

Just tested on 5.9.0b and bug is still here

10:36:09 MQT: tele/h801_bedroom/INFO1 = {"Module":"H801", "Version":"5.9.0b", "FallbackTopic":"h801_bedroom_4210BF", "GroupTopic":"sonoffs"}

@arendst
Copy link
Owner

arendst commented Nov 7, 2017

How about dimmer 99

@dimitrystd
Copy link
Author

Used console and mqtt, in both cases it works fine.

@arendst
Copy link
Owner

arendst commented Nov 7, 2017

For the Sonoff Led I clip dimmer at 99 as a value of 100 made the leds blink too much when the PWM pulses are probably non existent. I guess the same is true for the H801 but it shows as a Watchdog timeout.

I think I will clip dimmer at 99 for all other too. You won't notice any way... ;-)

@arendst
Copy link
Owner

arendst commented Nov 7, 2017

You might want to try the set pwmfrequency lower and see what happens with dimmer 100.

I have a Arilux which blinks fast and watchdog reboots at pwmfrequency 1600 and dimmer 100 but is steady at dimmer 99

@dimitrystd
Copy link
Author

12:25:37 CMD: PWMfrequency 600
12:25:37 MQT: stat/h801_bedroom/RESULT = {"PWMFrequency":600}
12:25:49 CMD: Dimmer 99
12:25:49 MQT: stat/h801_bedroom/RESULT = {"POWER":"ON", "Dimmer":99, "Color":"FCFCFC"}
12:25:55 CMD: Dimmer 100
12:25:55 MQT: stat/h801_bedroom/RESULT = {"POWER":"ON", "Dimmer":100, "Color":"FFFFFF"}

Again endless reboot.

My main pain point that there is no way to reset device. It's physically mounted under the bed. I have to deinstall it and to flash it two times (with blank and actual firmware) then do a couple additional adjustments that cannot be configured via code.

So, for now, i will change openhab configuration to never send 100. But would be nice to have the option to reset configuration without device deinstallation.

@arendst
Copy link
Owner

arendst commented Nov 7, 2017

During the reboot you might be able to enter command power off inthe web console. Then you have all the time to change the dimmer value below 100.

@dimitrystd
Copy link
Author

It doesn't connect to wifi, so i cannot use console or mqtt. I'm not sure how to send command via serial port, but it also means: deinstall device; unscrew case; connect laptop...

@arendst arendst added the enhancement Type - Enhancement that will be worked on label Nov 8, 2017
arendst added a commit that referenced this issue Nov 8, 2017
5.9.1a
 * Fix PWM watchdog timeout if Dimmer is set to 100 or Color set
to 0xFF (#1146)
@arendst arendst added the fixed Result - The work on the issue has ended label Nov 9, 2017
arendst added a commit that referenced this issue Dec 1, 2017
5.10.0 20171201
 * Upgrade library ArduinoJson to 5.11.2
 * Upgrade
library IRRemoteEsp8266 to 2.2.1 + 2 commits but disabled some protocols
(code size reduction)
 * Upgrade library NeoPixelBus to 2.2.9
 * Upgrade
library OneWire to 2.3.3 + 6 commits and disabled CRC lookup-table
(#define ONEWIRE_CRC8_TABLE 0) (code size reduction)
 * Update library
PubSubClient to 2.6 + 9 commits and additional delay (#790)
 * Update
core_esp8266_wiring_digital.c to latest (staged) level
 * Patch library
I2Cdevlib-Core for esp8266-core 2.4.0-rc2 compatibility
 * Remove
command EnergyReset 1..3 now replaced by ENergyReset1 to EnergyReset3
 *
Remove spaces in JSON messages (code size reduction)
 * Renamed
xsns_05_ds18x20.ino to xsns_05_ds18x20_legacy.ino still using library
OneWire and providing dynamic sensor scan
 * Fix possible iram1_0_seg
compile error by shrinking ICACHE_RAM_ATTR code usage
 * Fix PWM
watchdog timeout if Dimmer is set to 100 or Color set to 0xFF (#1146)
 *
Fix Sonoff Bridge Learn Mode hang caused by unrecognised RF code
(#1181)
 * Fix blank console log window by using XML character encoding
(#1187)
 * Fix wrong response name for command HlwISet (#1214)
 * Fix
DHT type sensor timeout recognition by distinguish "signal already
there" from "timeout" (#1233)
 * Add fixed color options 1..12 to
command Color
 * Add + (plus) and - (minus) to commands Dimmer
(+10/-10), Speed and Scheme
 * Add + (plus) and - (minus) to command
Color to select 1 out of 12 preset colors
 * Add + (plus) and - (minus)
to command Ct to control ColdWarm led ColorTemperature (+34/-34)
 * Add
commands EnergyReset1 0..42500, EnergyReset2 0..42500 and EnergyReset3
0..42500000
 *  to (Re)set Energy Today, Yesterday or Total respectively
in Wh (#406, #685, #1202)
 * Add optional ADS1115 driver as alternative
for unsupported I2Cdevlib in esp8266-core 2.4.0-rc2
 * Add support for
INA219 Voltage and Current sensor to be enabled in user_config.h with
define USE_INA219
 * Add support for Arilux LC11 (Clearing RF home code
when selecting no Arilux module)
 * Add support for WS2812 RGBW
ledstrips to be enabled in user_config.h with define USE_WS2812_CTYPE
(#1156)
 * Add SettingsSaveAll routine to command SaveData to be used
before controlled power down (#1202)
 * Add option PUSHBUTTON_TOGGLE
(SwitchMode 7) to allow toggling on any switch change (#1221)
 * Add new
xdrv_05_ds18x20.ino free from library OneWire and add the following
features:
 *  Add support for DS1822
 *  Add forced setting of 12-bit
resolution for selected device types (#1222)
 *  Add read temperature
retry counter (#1215)
 *  Fix lost sensors by performing sensor probe at
restart only thereby removing dynamic sensor probe (#1215)
 *  Fix
sensor address sorting using ascending sort on sensor type followed by
sensor address
 *  Rewrite JSON resulting in shorter message allowing
more sensors in default firmware image:
 *
"DS18B20-1":{"Id":"00000483C23A","Temperature":19.5},"DS18B20-2":{"Id":"0000048EC44C","Temperature":19.6}

* Add additional define in user_config.h to select either single sensor
(defines disabled), new multi sensor (USE_DS18X20) or legacy multi
sensor (USE_DS18X20_LEGACY)
 * Add clock support for more different
pixel counts (#1226)
 * Add support for Sonoff Dual R2 (#1249)
 * Add
FriendlyName to web page tab and add program information to web page
footer (#1275)
@stefan-wiesner
Copy link

Hi.

This did not solve this issue for me. It was neither the reset 1 nor reset 2 nor esptool.py --port COM5 erase_region 0x0F4000 0x008000 nor esptool.py --port COM5 erase_flash... It seemed that I totally messed up my Sonoff.

Fix for me was to download an empty 1MB flash BIN and flash it with the esptool like that:

python esptool.py --port COM5 write_flash -fs 1MB -fm dout 0x0 blank_1MB.bin

I put the bank_1MB.bin into the folder where the esptool.py was in. This really wipes the whole megabyte of flash memory.

The page to download the empty 1MB can be found here (link at the very bottom):

http:https://www.pratikpanda.com/completely-format-erase-esp8266-flash-memory/

With addressing other areas in the memory it is also possible to wipe 2MB of flash like shown in the article.

@arendst maybe you want to add it to the troubleshooting section - because the erase_flash command did not fix it for me and I was short befor throwing the sonoff into the trash... And thanks for the great Tasmota Software!

Hope it helps ...

@arendst arendst closed this as completed Jul 2, 2018
curzon01 pushed a commit to curzon01/Tasmota that referenced this issue Sep 6, 2018
5.9.1a
 * Fix PWM watchdog timeout if Dimmer is set to 100 or Color set
to 0xFF (arendst#1146)
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement Type - Enhancement that will be worked on fixed Result - The work on the issue has ended
Projects
None yet
Development

No branches or pull requests

3 participants