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

allow calling poll() with BLE event data #120

Closed
wants to merge 1 commit into from

Conversation

urish
Copy link

@urish urish commented Jan 20, 2017

Hi again Sandeep!

First of all, thank you again for your enormous contribution to the BLE community. I use your projects on a daily basis, and find them very valuable.

This pull request lets the user of the library pass the BLE event data to poll(), instead of have poll() get it directly from the BLE stack.

My use case for this is - I have an app that acts as a BLE peripheral, while at the same time scans for BLE advertisements from nearby devices. That's the reason why I need to get the raw SoftDevice events.

This is a sketch of how my code uses the proposed feature:

  uint32_t   evtBuf[(sizeof(ble_evt_t) + (GATT_MTU_SIZE_DEFAULT))];
  uint16_t   evtLen = sizeof(evtBuf);

  if (sd_ble_evt_get((uint8_t*)evtBuf, &evtLen) == NRF_SUCCESS) {
    ble_evt_t* bleEvt = (ble_evt_t*)evtBuf;
    // here I check if this is an BLE advertisement packet and handle it
  } else { 
    return;
  }

  BLECentral central = blePeripheral.central(evtBuf, evtLen);
  // do the usual stuff with the central object

So far, I have only implemented it for the NRF51 variant, as I wanted to get your feedback first, get your feedback about this approach, and see if it is heading the right direction. I would love to have some solution for my use case, and I am open for feedback on this PR before I continue working on this.

Thanks!

For use cases where you need to process the event data before/after arduino-BLEPeripheral kicks in
@sandeepmistry
Copy link
Owner

@urish not a bad idea, what you you think about the opposite?

Having a API in BLEPeripheral to set a callback to trigger when an event is received? This would be portable to both nRF8001 and nRF51/nRF51.

Longer term, I think a new library needs to be created for combined central and peripheral functionality. nRF8001 can be left out of the new library.

Arduino and Intel have the next generation API defined in the CurieBLE master: https://github.com/01org/corelibs-arduino101/tree/master/libraries/CurieBLE

We're still working together to refine a few things. Do you have time to start on the new library nRF51/nRF52 boards?

@urish
Copy link
Author

urish commented Jan 30, 2017

Actually, I have implemented the opposite just before going this direction, but I liked this approach more - if we introduce an API that is triggered whenever an event is received, it would need to pass the event data to the user - and then, it would either need to always save the latest event data in some memory location, or the user will need to make sure he is not using the event data outside the handler.

As for CurieBLE - I like the approach of having a library that combines central and peripheral (AFAIK the RBL implementation does exactly that), though, I prefer the MIT license that you have here over LGPL, at least when it comes to embedded devices.

@sandeepmistry
Copy link
Owner

@urish ok, how do you suggest we move forward?

@urish
Copy link
Author

urish commented Jan 30, 2017

If you are open to it, I can try to implement poll(void* , uint16_t) for the nRF8001 and update API.md accordingly. Though, I don't have an actual nRF8001 chip here, so I will only be able to verify that the code compiles and seems to do the right thing. Thoughts?

@sandeepmistry
Copy link
Owner

I still prefer the opposite, as there are a lot of internal calls in the library itself to poll(), for example:

Adding a callback for the event data will also help with the discussion in #115 (comment)

@urish
Copy link
Author

urish commented Feb 4, 2017

Okay, I will try to do it the other way. Currently, I see that all events handlers get just the central as a parameters. We could store a copy of the last event received in the central object, and then the user's event handler implementation will pull it from there, though, I am not sure that it is the cleanest way to do it. Thoughts?

@sandeepmistry
Copy link
Owner

@urish good question.

Maybe an API like setRawEventHandler(callback)

where callback has a signature of

void callback(int eventId, const byte eventData[]) {
  // ...
}

A type of const void* could also be an option, this should work nicely for both nR8001 and nRF51822.

Thoughts?

@urish
Copy link
Author

urish commented Mar 12, 2017

Hi Sandeep, my focus has shifted to Espruino for this project. However, if you are still interested, I will try to create a PR for this feature with the callback approach.

@sandeepmistry
Copy link
Owner

@urish sure, I think the feature is still valuable.

Do you have a link to your Espruino work?

@urish
Copy link
Author

urish commented Mar 17, 2017

@floe
Copy link
Contributor

floe commented Oct 23, 2017

FWIW, I've updated #155 with a couple of new handlers for BLEDeviceEvent* - maybe have a look there & comment, I think it's similar to what was proposed here earlier.

@urish
Copy link
Author

urish commented Jul 29, 2020

Closing due to inactivity.

@urish urish closed this Jul 29, 2020
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants