1.19beta7 and WiFi connect
-
upps… did it again...
after some hours online a reboot was needed, and afterwards no WiFi connection was establised.[[language]] >>> M552 SENDING:M552 WiFi module is idle >>> M552 S1 SENDING:M552 S1 WiFi reported error: Unexpected WiFi state 'idle' while trying to connect to Wifi module is idle
And no, it isn't an error of me that the "currentSsid" which should come after "… connect to ..." is missing.
So i think the config couldn't be read although M587 did list the known SSIDs[[language]] >>> M587 SENDING:M587 Remembered networks: xxxx yyyy z.z
-
Thanks, that gives me something to go on. If you try sending M552 S1 a few more times, does it connect eventually? If not, try M552 S-1 followed by M552 S1.
-
nope… this time no changes...
[[language]] >>> M552 S1 SENDING:M552 S1 WiFi reported error: Unexpected WiFi state 'idle' while trying to connect to Wifi module is idle >>> M552 S1 SENDING:M552 S1 WiFi reported error: Unexpected WiFi state 'idle' while trying to connect to Wifi module is idle >>> M552 S1 SENDING:M552 S1 WiFi reported error: Unexpected WiFi state 'idle' while trying to connect to Wifi module is idle >>> M552 S1 SENDING:M552 S1 WiFi reported error: Unexpected WiFi state 'idle' while trying to connect to Wifi module is idle >>> M552 S1 SENDING:M552 S1 WiFi reported error: Unexpected WiFi state 'idle' while trying to connect to Wifi module is idle >>> M552 S1 SENDING:M552 S1 WiFi reported error: Unexpected WiFi state 'idle' while trying to connect to Wifi module is idle >>> M552 S1 SENDING:M552 S1 WiFi reported error: Unexpected WiFi state 'idle' while trying to connect to Wifi module is idle >>> M552 S-1 SENDING:M552 S-1 WiFi module stopped >>> M552 S1 SENDING:M552 S1 WiFi module started WiFi reported error: Unexpected WiFi state 'idle' while trying to connect to Wifi module is idle >>> M552 S1 SENDING:M552 S1 WiFi reported error: Unexpected WiFi state 'idle' while trying to connect to Wifi module is idle >>> M552 S1 SENDING:M552 S1 WiFi reported error: Unexpected WiFi state 'idle' while trying to connect to Wifi module is idle >>> M552 S-1 SENDING:M552 S-1 WiFi module stopped >>> M552 S1 SENDING:M552 S1 WiFi module started WiFi reported error: Unexpected WiFi state 'idle' while trying to connect to Wifi module is idle
15-30 seconds between each try.
-
ok tested a little bit more… there seems to be a bug with EEPROM put/get.
szenario: all known SSIDs are deleted with M588 S"" and all AP configurations are deleted also with M589 S"".
[[language]] M588 S"*" ok M589 S"*" ok M587 No remembered networks ok
after that i established an AP config which is listed correctly with M587
[[language]] M589 S"duet" P"duet" I192.168.1.1 ok M587 Remembered networks: duet ok
when i try to start AP mode -> error, but AP config seems to be still stored
[[language]] M552 S2 ok WiFi reported error: Failed to start access point Wifi module is idle M587 Remembered networks: duet ok
add an client config and list again known configs the AP config is gone
[[language]] M587 S"test" P"test" ok M587 Remembered networks: test
-
M587 should not list the AP name as a remembered network if you are using beta 8 of DuetWiFiFirmware. Please check which version you are running. Tomorrow I'll check for coding errors in that area.
-
WifiServer beta8 and RRF beta8. see below:
[[language]] M122 === Diagnostics === Used output buffers: 1 of 32 (1 max) === Platform === RepRapFirmware for Duet WiFi version 1.19beta8 running on Duet WiFi 1.0 Board ID: xxxx Static ram used: 20900 Dynamic ram used: 96084 Recycled dynamic ram: 1800 Stack ram used: 3960 current, 4784 maximum Never used ram: 7504 Last reset 00:00:47 ago, cause: power up Last software reset reason: User, spinning module GCodes, available RAM 7180 bytes (slot 2) Software reset code 0x0003, HFSR 0x00000000, CFSR 0x00000000, ICSR 0x00400000, BFAR 0xe000ed38, SP 0xffffffff Error status: 0 Free file entries: 10 SD card 0 detected, interface speed: 20.0MBytes/sec SD card longest block write time: 0.0ms MCU temperature: min -210.4, current 41.4, max 41.5 Supply voltage: min 0.1, current 0.5, max 0.8, under voltage events: 0, over voltage events: 0 Driver 0: ok Driver 1: ok Driver 2: ok Driver 3: ok Driver 4: ok Date/time: 1970-01-01 00:00:00 Slowest main loop (seconds): 0.001695; fastest: 0.000027 === Move === MaxReps: 0, StepErrors: 0, MaxWait: 0ms, Underruns: 0, 0 Scheduled moves: 0, completed moves: 0 Bed compensation in use: none Bed probe heights: 0.000 0.000 0.000 0.000 0.000 Probe change coordinates: === Heat === Bed heater = 0, chamber heater = -1 === GCodes === Segments left: 0 Stack records: 2 allocated, 0 in use Movement lock held by null http is idle in state(s) 0 telnet is idle in state(s) 0 file is idle in state(s) 0 serial is ready with "M122" in state(s) 0 aux is idle in state(s) 0 daemon is idle in state(s) 0 queue is idle in state(s) 0 Code queue is empty. Network state is running WiFi module is idle WiFi firmware version 1.19beta8 WiFi MAC address aa:bb:cc:dd:ee:ff WiFi Vcc 3.10, reset reason Turned on by main processor WiFi flash size 4194304, free heap 41104 HTTP sessions: 0 of 8 Socket states: 0 0 0 0 0 0 0 0 Responder states: HTTP(0) HTTP(0) HTTP(0) HTTP(0) FTP(0) Telnet(0) ok
-
OK, I found the bug, it's purely a reporting issue. If you have no remembered networks but you have specified an access point name, then when you list remembered networks it prints the access point name. After you have added a remembered network, you can still retrieve the own access point name by sending M589. The fix will be in the next beta.
I still haven't worked out why it's trying to connect to an empty SSID. I'll look at that later today.
-
@dc42: as per definition the passphrase within the AP mode hast to be at least 8 chars long, i think it would be reasonable to check for valid M589 input (i think ssid min 0 max 32 chars and passphrase min 8-64 chars).
try:[[language]] M552 S0 ok WiFi module started M589 S"test" P"test" I192.168.1.1 ok M552 S2 ok WiFi module started WiFi reported error: Failed to start access point Wifi module is idle M589 S"test" P"testtest" I192.168.1.1 ok M552 S2 ok Wifi module is providing access point test, IP address 192.168.1.1
-
Thanks for the suggestion, I'll implement it in the next beta.
I can't reproduce the problem with failing to connect and not displaying the SSID name, but I've built a new DuetWiFiServer.bin with some changes that may help and put it at https://dl.dropboxusercontent.com/u/19369680/DuetWiFiServer.bin. Please try it.
-
will give it a try. will give feedback tomorrow.
is there the possibility to erase the ESP (incl. flash) completly from SAM/RRF? or only via ISP? -
@dc: i think i found the reason, why an empty config was read…
SocketServer.cpp - row 64
[[language]] for (size_t i = 1; i <= MaxRememberedNetworks; ++i)
shouldn't it be```
[[language]]
for (size_t i = 0; i <= MaxRememberedNetworks; ++i)same in row 83 or better (i think) not to waste one slot at the beginning (row 64, 83, 112, 521,…)
[[language]]
for (size_t i = 0; i < MaxRememberedNetworks; i++) -
The first entry is the configuration for the WiFi module as an access point. So the count starts from 1 when it is searching for a remembered SSID.
-
hmmm… once again:
[[language]] for (int8_t i = 0; i < num_ssids; ++i) { if ((strongestNetwork < 0 || WiFi.RSSI(i) > WiFi.RSSI(strongestNetwork)) && RetrieveSsidData(WiFi.SSID(i).c_str(), ssidData)) { strongestNetwork = i; } }
WiFi.RSSI's and WiFi.SSID's parameters are a zero based index from prior discovered SSIDs by blocking WiFi.scanNetworks(false, true)
At this point we are looking at the wrong index. aren't we? ++i -> i++ -
@dc: 1.19beta8+1 doesn't change the WiFi behaviour. but can you plz. confirm/check the above post?
-
Using ++i or i++ does exactly the same thing if the operand has primitive type and you don't use the value within the same expression, as in this case.
-
I just got a Duet Wifi and I'm having a hell of a time with the WIFI setup. I have tried flashing 1.18 stable as well as 1.19 beta 8. I first attempted upgrades via M997 but eventually tried the erase/reset/reload via samba. I have gotten it to connect once or twice but it seems whenever I edit config.g to uncomment M552 S1 it fails to connect again after reboot. I have fiddled with it quite a bit since then and haven't been able to get it to talk to my router again.
I've noticed a couple things
- when using 1.18 M552 will say that the board is in AP mode but I can't see it in my list of WIFI networks.
- when it does this it also says hostname is some bunch of gibberish ascii characters
- when using 1.19 Beta 8 M587 returns the two remembered networks I have configured in my SetNetwork macro however when I do a M552 S1 I get
M587
SENDING:M587
Remembered networks:
seawest
seawest 5G
M552 S1
SENDING:M552 S1
WiFi reported error: no known networks found
Wifi module is idleI'm starting to think the board is faulty. Is there anything else I can try? It's almost as if the WIFI module is retaining some kind of garbage. Is there a way to purge everything so I'm starting fresh? SD Card, memory, everything?
-
The "no known networks found" message means that it did a network scan and didn't find either of the SSIDs you configured. How strong is the signal from your router where the Duet is? Is the Duet surrounded by metalwork that would attenuate the signal?
The Duet WiFi does 2.4GHz only, and I presume seawest 5G is a 5GHz access point.
I think access point names are case sensitive. Is 'seawest' exactly how your access point name appears when you connect to it from a smartphone, tablet etc. ?
-
wow thanks for the quick reply. seawest is the name of my 2.4 Ghz network and my seawest 5G is my 5 Ghz network. Both are off of the same ASUS router that sits about 10 feet away. The names are case sensitive and exactly as they're seen from my iphone. My password is alphanumeric and only contains letters and a number.
The thing that makes me suspicious that the board is bad is the fact that I don't see "Duet WIFI" when the board thinks it's in AP mode when using 1.18. Are there any debug commands I can use to test the functionality of the WIFI module itself? I was able to get the board to connect a handful of times and it seemed tied to loading a new WIFI firmware. However, I have tried reloading firmware several times since then and I haven't been able to re-establish a connection.
I WAS able to connect to the "Duet WIFI" SSID but only once. When that occurred I could see my neighbor's APs as well as my own. I was also able to get into the web interface but as soon as I uncommented "M552 S1" and rebooted I had the same problems all over again and could not reconnect.
-
When you are using firmware 1.18 and the Duet reports that it is in AP mode, you should be able to find it in the network listing on your smartphone assuming your smartphone isn't only looking for 5GHz networks. If you can't, ask for the Duet to be replaced.
-
@DC42: regaring the SSID/PSK topic:
within the StartClient() you are calling RetrieveSsidData() which overwrites ssidData each time it is called with data from EEPROM.
But at the end of StartClient() you are calling ConnectToAccessPoint() with the last update of ssidData as parameter (which could store wrong data at this point caused by prior RetrieveSsidData() calls).i think RetrieveSsidData() should be called again with WiFi.SSID(strongestNetwork) as paramter right after the strongestNetwork was found to update ssidData with the correct parameters again. adopted version: https://www.dropbox.com/s/60djqiyv9f380xe/DuetWiFiServer.bin?dl=0