-
Notifications
You must be signed in to change notification settings - Fork 435
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
Set the default max MTU size within the DFU transport to 23 #293
Conversation
…h is the required size for the legacy bootloader to perform a successful OTA with the latest Nordic-DFU-Library.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I see, it seems to be the lack of memory issue with higher MTU. Though 23 is a bit slow, can you try with a few higher MTU such as 50, 70, or 100 to see if we could have an optimum MTU.
So I think it is a bit different than that. As I mentioned on the issue, one can use an older version of nRF Connect App e.g. v4.24.3 and then the MTU can be left as 247 (or to be honest, any number). You see, I tried experimenting with different MTU sizes and nRF Connect versions and noticed this:
I searched this up within Nordic-DFU-Library and I found some proof that the current Nordic DFU Library allows using higher MTU values than 23, but 'MTU > 23 is only supported in the official Secure DFU from SDK 15 onwards.', more on the matter here and here. Knowing that the Adafruit nRF Bootloader is an older unsecure version we can safely assume that for this to work we have to set the MTU to 23. The only thing I am not fully sure is why when I set the MTU to 23 and use nRF Connect v4.26.0, the avg. firmware upload speed is 2.8 kB/s, which is lower than 4 kB/s, which can be achieved with nRF Connect v4.24.3. The only explanation is that something else changed within Nordic DFU Library, that affects this, which has nothing to do with the MTU size. Note this does not affect the MTU speed when used within the application mode, I tested this using the throughput.ino example by requesting to change to different MTU values there:
Regardless, now we know that this fix will not affect the older version of the Nordic-DFU-Library (e.g. the one used with nRF Connect App v4.24.3), since it would enforces the MTU to be 23 regardless (meaning it is backwards compatible). Then, it will ensure that we can use Adafruit nRF52 Bootloader with the latest version of the nRF Connect App, nRF Toolbox and the Nordic-DFU-Library, meaning it will work with Android 12 and will also support Flutter! |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
thank you very much for your sufficient testing. Indeed this cross-version compatible is a bit headache, which explain why I haven't experienced the issue under my mobile setup and others has quite a bit of issue with this. Changing back to normal MTU=23 even though is a bit slow but seems to be the safest thing to do for now. When having more time to test with nrf mobile API, we will re-increase it if needded.
Just to clarify, I went through the comments and discussions on the Nordic DFU Library github. I found out that the previous version of Nordic DFU Library was forcing MTU=23 regardless of the value set within the bootloader. This was due to both the Nordic DFU Library not being able to support higher MTUs nor the non-secure bootloader. Then, in the latest versions of the Nordic DFU Library they enabled support for higher values of MTUs, which work with a configured secure bootloader. So keeping this in mind, if we want higher MTUs in the future, the bootloader will have to become secure, however I understand that would require a whole rewriting of the bootloader, is that right? |
Hmm. Has anyone else noticed this? Making this change seems to resolve the issue with Android devices and OTAs hanging at 100%. I can now successfully flash them. However, it appears to cause issues with Apple devices now. Previously, I had no issues flashing, in fact they performed much better with Apple. But, now I'm unable to flash with my iPhone/Macbook even though my iPad (5th gen) works. Of course Android is working now too. |
@rcarteraz Could you please share a bit more information on the versions that you have tested and what did you try e.g. can you fill this in:
I am not sure if you can install an older version of nRF Connect on iPhone, but maybe on Macbook it should be possible finding an older version. When you do this, I could then take a look and see if there are any obvious fixes. What I am trying to understand here is whether this setting breaks something that worked or instead it fixes the issue for the Android system, but does not fully fix for Apple Ecosystem. |
Yeah I can take a stab at trying that tomorrow (rather later today). I did find that for iOS/macOS if I enabled PRN and changed the packets to 6 in the settings it would successfully flash. Weirdly, that's not required on my iPad though it just works still. This was with the DFU app, not nRF connect but I think that can be set there too and I'll try. I'll add more later. |
@rcarteraz So the DFU app uses the same library, so ultimately it's the same thing. I am simply not sure which version of DFU app did the updates the "old" way... I am sure it's possible to track this down from the github release list on nRF repo. |
It appears the apple apps do not use those version numbers. For nRF Connect the latest version is 2.6.4 and the DFU app is 1.1. Additionally, I'm not aware of a way to test the older versions as the app store does not allow you to select the version. |
The interesting thing though, on iOS, there wasn't an issue with OTA updates like there was on Android. It worked quite well on iOS. Would upload at 11kbs and finish every time. Until, testing this change to fix Android. I've found a way to make it work on Apple but it's not ideal and also really slow, around 3.8kbs. But if you go into the settings of the DFU app and enable PRN (Packets Receipt Notification) and change the value to 6. It'll work. I tried 12 but it didn't work so not sure if there's more options between those two number. Will see if there's an option like this in nRF Connect. |
Changed the default max MTU size within the DFU transport to 23, which is the required size for the legacy bootloader to perform a successful OTA with the latest Nordic-DFU-Library. This resolves #287.