-
Notifications
You must be signed in to change notification settings - Fork 274
RX2 fallback leads to endless downlinks #767
Comments
This is an issue for https://github.com/TheThingsNetwork/ttn, not https://github.com/TheThingsNetwork/lorawan-stack. I'll transfer it. |
It is a important bug, i have few customers which lost its devices due to this bug. I think in OTAA, there is no need to change the SF of the RX2 after the join-accept. If the device receives the join-accept then it is configured to receive in SF9 on RX2. For ABP, I think it should be better to configure by using the RX1 window.... |
If you have problems with this in a private deployment, you can configure it to use a different RX2 data rate with the Since the core team is working full-time on v3, you may want to contribute a fix for this yourself. My suggestion would be to add a "activated at" field to the device so that the NS can detect if it's an OTAA device or not. This field can then be set by HandleActivate after which the fallback can be bypassed for devices that have been activated with OTAA. |
I don't know if everything is correct and compilable (my first contribution in GO 😀), but I've implemented the suggestions of @htdvisser. Some things to remind: The Thanks so far! |
I'm currently also affected by this. One of my devices joined using OTAA. Then we had the recent gateway outage and the device never received downlinks. The device (ADR) therefore moved all the way to SF12. Using an SDR I can see it is transmitting on SF12 and the downlinks are also sent on SF12, not on SF9 like it should be. @sigmaroot @htdvisser how can I assist getting this bugfix tested and out on production TTN? |
Looking at the fallback code, the line that does the fallback magic is: Can't we change that line to:
With this change (if I understand the code correctly) we will alternate between the incorrect (SF12) downlink and the correct (SF9) downlink. |
I'm still stuck with one deployment because of this bug. Steps to reproduce:
I can't find a workaround to get the device to receive the downlinks again other than to power cycle it to force a re-join. Is there any other way I can force downlinks back to SF9? |
@jpmeijers |
I think there are two different discussions here. One is regarding privately hosted work, another is regarding existing apps deployed using TTN. As I don't have a privately-hosted V2 network, changes for private networks are interesting but don't address our issues. @htdvisser Will pushing a change request on the V2 code make it to production, or is TTN V2 basically frozen at this point, or is there some other way to fix it? Those of us with deployed systems need to understand so we can explain to our stakeholders. It would be good to avoid visits to the devices, and better to avoid firmware updates in devices; but it would be great, no matter how we mitigate, to make sure we only visit devices once. Thanks! |
As you can imagine, we're trying to spend all our time on v3 and only do really critical things on v2. Of course we do welcome contributions, so if you're willing to implement a fix and test it on a private network, I'll make sure it gets merged and deployed to the public community network. |
I see this as a critical issue as it causes some of my devices to be stuck on SF12, sending retries and draining their batteries. It also prevents me from having remote control of these devices. Because of this I tried the suggestions in this thread, implemented them on a private instance of the stack on my local computer, and tested. PR #768 contains a working fix. |
Exactly, It is a critical issue on public ttn V2. We lost a lot of devices in downlink...
Best regards,
Mathieu Pouillot
Ingénieur Responsable Produit
Tél. : +33(0)4 98 01 60 06
nke Watteco
Valgora Bat C
Avenue Alfred Kastler
83160 LA VALETTE DU VAR – France
http://www.nke-watteco.fr
http://www.nke-watteco.com
…________________________________
De : JP Meijers <[email protected]>
Envoyé : lundi 14 octobre 2019 21:26:04
À : TheThingsNetwork/ttn <[email protected]>
Cc : M Pouillot <[email protected]>; Comment <[email protected]>
Objet : Re: [TheThingsNetwork/ttn] RX2 fallback leads to endless downlinks (#767)
I see this as a critical issue as it causes some of my devices to be stuck on SF12, sending retries and draining their batteries. It also prevents me from having remote control of these devices.
Because of this I tried the suggestions in this thread, implemented them on a private instance of the stack on my local computer, and tested. PR #768<#768> contains a working fix.
—
You are receiving this because you commented.
Reply to this email directly, view it on GitHub<#767>, or unsubscribe<https://github.com/notifications/unsubscribe-auth/AJLZSWEQK4AWRXRVKSW6763QOTBUZANCNFSM4ILVNGHA>.
|
Thanks for contributing 😄 |
I just realised this fix will only be applied to devices that join after the fix is applied. Devices that are using a session from a join before today will still suffer from this bug. On my side that means half of my devices (that automatically rejoins periodically) are now working as expected, while the other half (which never performs a re-join) will still not receive downlinks. |
As ADR-enabled OTAA devices that joined before October 2019, and all ADR-enabled ABP devices are still running into this†, I wonder if it would be worthwhile to fix this for those in V2 too? ONLY IF YES, then I wonder:
† A recent case from Slack shows an Elsys OTAA device that dropped to SF12 after some outage, and since already missed 39,000+ (still counting) RX2 downlinks on SF12, with an FOpts of |
Summary
If a MAC command sent in RX2/SF9 was not answered by an end node, the NS is using RX2/SF12 as a fallback. In case that the end node IS listening on RX2/SF9 and just missed the MAC command (due to temporarely unavailability or bad reachability) it will never receive the fallback MACs on RX2/SF12. In that case, again no answer is sent by the end node and the NS starts repeating the requests (LinkADRReq and RXParamSetupReq). That produces a huge amount of downlinks that will never be received by the end node that is still listening on RX2/SF9.
Steps to Reproduce
What is already there? What do you see now?
What is missing? What do you want to see?
Not the same downlink again and again.
Environment
Not relevant.
How do you propose to implement this?
The RX2 fallback should not be used more than 2 times (for example). After 2 missed answeres, the RX2 should be changed back to SF9 again. After 3 cycles of RX2/SF9-RX2/SF12 changes some notification should be generated ("end node not answering any MAC") and the downlinks should be stopped. A restart of the procedure after an amount of time may be possible.
Can you do this yourself and submit a Pull Request?
No.
The text was updated successfully, but these errors were encountered: