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

Add unofficial support for ANT and Dual stack softdevices #146

Closed
huddy987 opened this issue Jul 14, 2020 · 7 comments
Closed

Add unofficial support for ANT and Dual stack softdevices #146

huddy987 opened this issue Jul 14, 2020 · 7 comments
Labels
enhancement New feature or request

Comments

@huddy987
Copy link

huddy987 commented Jul 14, 2020

Currently, if we want to build the bootloader with ANT or dual stack softdevices, we have to resort to hacking our own solution as @orrmany has done. From my understanding the current issue is that the ANT/Dual softdevices aren't allowed to be distributed, and so pre-patched bootloaders with the ANT/Dual softdevices can't be distributed either. My proposition is that we allow new targets in the makefiles to build bootloaders with these softdevices, but leave it up to the user to download the appropriate softdevice.

My idea is to change the makefile from:
make BOARD=XXXXX
to
make BOARD=XXXXX STACK=XXXXX
where stack is either "BLE" "ANT" or "BOTH"

When BLE is selected, we can handle building the same way we currently do.

For ANT, it's actually pretty simple. The S212 7.0.1 softdevice supports nRF52832, nRF52810, nRF52833, and nRF52840. So we can use the S212 softdevice as a cover-all solution.

For dualstack, we would need to use S332 for nRF52832, and S340 for nRF52840. We could use 6.1.1, or update to 7.0.1 (doesn't really matter to me).

In any case, the main change would be to create linker scripts for each of these bootloaders, and compile switch in out BLE and ANT code for the single stack softdevices. If a user tries to build without having the ANT/dual stack softdevices, we can just prompt the user to download the stack from thisisant.com.

Of course, this would have to remain as unofficially supported because we can't actually distribute the proposed "new" bootloaders. Users of the "new" bootloaders would be on their own to interface with the softdevices ANT APIs in their apps. All this change would mean is that using ANT with adafruit's arduino library is a bit less tedious.

Thoughts? I took a look at this last night, and thanks to the decoupling of the SD and bootloader, it shouldn't be too hard to do this. If this seems like a reasonable idea I can do the PR.

@huddy987 huddy987 added the enhancement New feature or request label Jul 14, 2020
@hathach
Copy link
Member

hathach commented Jul 14, 2020

SoftDevice is decoupled and not considered as part of bootloader anymore. You could just update it using uf2 file of any Sxxx you like. Feature is merged, just not released yet. ref #128

@hathach hathach closed this as completed Jul 14, 2020
@huddy987
Copy link
Author

There is some BLE code in the bootloader that won't work with the single ANT stack softdevice as well as sd_softdevice_init requires the ANT license parameter...it would be nice to at least have compile switch to compile in/out the required ANT changes

@hathach
Copy link
Member

hathach commented Jul 14, 2020

can you be more specific to point out which function or line that doesn't work, and what the result of those running on your setup. We can discuss on how to address those issues.

UPDATE: The SD is decoupled, therefore I didn't want to add make option to "support" more SoftDevice. The S132/S140 has to be there to keep existing user happy and on the plus side we can distribute it. How about just ask user to download ANT stack, convert it to uf2 and do the upgrade (with the help of a custom script).

@huddy987
Copy link
Author

huddy987 commented Jul 14, 2020

I'll need to look into it deeper, but here's a couple preliminary issues that would need to be compile switched in/out

SD_softdevice_enable requires the ANT license key parameter for ANT and DUAL stack softdevices:

APP_ERROR_CHECK( sd_softdevice_enable(&clock_cfg, app_error_fault_handler) );

SD_ble_enable is not a valid API call for ANT only softdevice. This will cause a hardfault:

APP_ERROR_CHECK( sd_ble_enable(&ram_start) );

You get the idea. Any BLE code in main.c will cause hardfaults on the ANT-only softdevice. For dualstack softdevices this shouldn't be a problem and can remain as is.

@hathach
Copy link
Member

hathach commented Jul 15, 2020

Ok, for sd_softdevice_enable we just need to add an check to softdevice version S132 or S140 or ANT one to call the correct API. Therefore we still don't need to have it as compiler switch. Since I don't have access to any ANT stack, would you mind submitting a PR for detecting and initialize the stack probably ?

@huddy987
Copy link
Author

Oh yes true, we won’t need any compiler switch, we can just do the following checks for initializing the stack properly:

S3XX = ANT + BLE => Do ANT and BLE init
S2XX = ANT => Only init ANT
S1XX = BLE => Only init BLE

I will take a look at this in the coming days

@hathach
Copy link
Member

hathach commented Jul 15, 2020

the SD inited is for OTA, the current code is too specific for BLE. I would suggest in case of S2xx (ANT only), you should skip the OTA mode, since it does not likely to work. May need a bigger PR to support OTA over ANT.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request
Projects
None yet
Development

No branches or pull requests

2 participants