2014-07-30 10:36:32 +00:00
|
|
|
/* mbed Microcontroller Library
|
|
|
|
* Copyright (c) 2006-2013 ARM Limited
|
|
|
|
*
|
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
* you may not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at
|
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
* limitations under the License.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef __NRF51822_H__
|
|
|
|
#define __NRF51822_H__
|
|
|
|
|
2015-06-19 12:39:08 +00:00
|
|
|
#include "ble/BLE.h"
|
2015-10-28 14:05:27 +00:00
|
|
|
#include "ble/blecommon.h"
|
|
|
|
#include "ble/BLEInstanceBase.h"
|
|
|
|
|
2015-07-06 13:17:22 +00:00
|
|
|
#include "nRF5xGap.h"
|
|
|
|
#include "nRF5xGattServer.h"
|
|
|
|
#include "nRF5xGattClient.h"
|
|
|
|
#include "nRF5xSecurityManager.h"
|
2015-10-28 14:05:27 +00:00
|
|
|
|
2015-04-14 12:25:19 +00:00
|
|
|
#include "btle.h"
|
2014-07-30 10:36:32 +00:00
|
|
|
|
2015-07-06 13:17:22 +00:00
|
|
|
class nRF5xn : public BLEInstanceBase
|
2014-07-30 10:36:32 +00:00
|
|
|
{
|
|
|
|
public:
|
2015-07-06 13:17:22 +00:00
|
|
|
nRF5xn(void);
|
|
|
|
virtual ~nRF5xn(void);
|
2014-07-30 10:36:32 +00:00
|
|
|
|
2015-11-03 12:40:34 +00:00
|
|
|
virtual ble_error_t init(BLE::InstanceID_t instanceID, FunctionPointerWithContext<BLE::InitializationCompleteCallbackContext *> callback);
|
2015-10-28 14:05:27 +00:00
|
|
|
virtual bool hasInitialized(void) const {
|
|
|
|
return initialized;
|
|
|
|
}
|
2015-06-19 07:28:35 +00:00
|
|
|
virtual ble_error_t shutdown(void);
|
2014-07-30 10:36:32 +00:00
|
|
|
virtual const char *getVersion(void);
|
|
|
|
|
Modify shutdown due to BLE API change
The module is updated to comply with the changes to BLE API regarding correct
shutdown functionality. The following changes are introduced to ble-nrf51822:
* Calls to the old static function shutdown in Gap, GattClient, GattServer and
SecurityManager are removed.
* The cleanup function in Gap, GattClient, GattServer and SecurityManager is
renamed to `reset()` and made public.
* The static references inside nRF5xGap, nRF5xGattClient, nRF5xGattServer and
nRF5xSecurityManager to objects of their own class are moved to nRF5xn.
* The static getInstance accessors in nRF5xGap, nRF5xGattClient,
nRF5xGattServer and nRF5xSecurityManager are removed and their functionality is
moved to the implemented virtual accessors in nRF5xn i.e. getGap(),
getGattClient, etc.
* A static function Instance is added to nRF5xn class to make the transport
object accessible across the module.
2015-12-14 15:15:35 +00:00
|
|
|
/**
|
|
|
|
* Accessors to GAP. This function checks whether gapInstance points to an
|
|
|
|
* object. If if does not, then the gapInstance is updated to
|
|
|
|
* &_getInstance before returning.
|
|
|
|
*
|
|
|
|
* @return A reference to GattServer.
|
|
|
|
*
|
|
|
|
* @note Unlike the GattClient, GattServer and SecurityManager, Gap is
|
|
|
|
* always needed in a BLE application. Therefore it is allocated
|
|
|
|
* statically.
|
|
|
|
*/
|
2015-06-18 20:27:29 +00:00
|
|
|
virtual Gap &getGap() {
|
Modify shutdown due to BLE API change
The module is updated to comply with the changes to BLE API regarding correct
shutdown functionality. The following changes are introduced to ble-nrf51822:
* Calls to the old static function shutdown in Gap, GattClient, GattServer and
SecurityManager are removed.
* The cleanup function in Gap, GattClient, GattServer and SecurityManager is
renamed to `reset()` and made public.
* The static references inside nRF5xGap, nRF5xGattClient, nRF5xGattServer and
nRF5xSecurityManager to objects of their own class are moved to nRF5xn.
* The static getInstance accessors in nRF5xGap, nRF5xGattClient,
nRF5xGattServer and nRF5xSecurityManager are removed and their functionality is
moved to the implemented virtual accessors in nRF5xn i.e. getGap(),
getGattClient, etc.
* A static function Instance is added to nRF5xn class to make the transport
object accessible across the module.
2015-12-14 15:15:35 +00:00
|
|
|
if (gapInstance == NULL) {
|
|
|
|
gapInstance = &_gapInstance;
|
|
|
|
}
|
|
|
|
return *gapInstance;
|
2015-06-18 13:12:50 +00:00
|
|
|
};
|
Modify shutdown due to BLE API change
The module is updated to comply with the changes to BLE API regarding correct
shutdown functionality. The following changes are introduced to ble-nrf51822:
* Calls to the old static function shutdown in Gap, GattClient, GattServer and
SecurityManager are removed.
* The cleanup function in Gap, GattClient, GattServer and SecurityManager is
renamed to `reset()` and made public.
* The static references inside nRF5xGap, nRF5xGattClient, nRF5xGattServer and
nRF5xSecurityManager to objects of their own class are moved to nRF5xn.
* The static getInstance accessors in nRF5xGap, nRF5xGattClient,
nRF5xGattServer and nRF5xSecurityManager are removed and their functionality is
moved to the implemented virtual accessors in nRF5xn i.e. getGap(),
getGattClient, etc.
* A static function Instance is added to nRF5xn class to make the transport
object accessible across the module.
2015-12-14 15:15:35 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Accessors to GATT Server. This function checks whether a GattServer
|
|
|
|
* object was previously instantiated. If such object does not exist, then
|
|
|
|
* it is created before returning.
|
|
|
|
*
|
|
|
|
* @return A reference to GattServer.
|
|
|
|
*/
|
2014-07-30 10:36:32 +00:00
|
|
|
virtual GattServer &getGattServer() {
|
Modify shutdown due to BLE API change
The module is updated to comply with the changes to BLE API regarding correct
shutdown functionality. The following changes are introduced to ble-nrf51822:
* Calls to the old static function shutdown in Gap, GattClient, GattServer and
SecurityManager are removed.
* The cleanup function in Gap, GattClient, GattServer and SecurityManager is
renamed to `reset()` and made public.
* The static references inside nRF5xGap, nRF5xGattClient, nRF5xGattServer and
nRF5xSecurityManager to objects of their own class are moved to nRF5xn.
* The static getInstance accessors in nRF5xGap, nRF5xGattClient,
nRF5xGattServer and nRF5xSecurityManager are removed and their functionality is
moved to the implemented virtual accessors in nRF5xn i.e. getGap(),
getGattClient, etc.
* A static function Instance is added to nRF5xn class to make the transport
object accessible across the module.
2015-12-14 15:15:35 +00:00
|
|
|
if (gattServerInstance == NULL) {
|
|
|
|
gattServerInstance = new nRF5xGattServer();
|
|
|
|
}
|
|
|
|
return *gattServerInstance;
|
2015-06-18 20:23:08 +00:00
|
|
|
};
|
Modify shutdown due to BLE API change
The module is updated to comply with the changes to BLE API regarding correct
shutdown functionality. The following changes are introduced to ble-nrf51822:
* Calls to the old static function shutdown in Gap, GattClient, GattServer and
SecurityManager are removed.
* The cleanup function in Gap, GattClient, GattServer and SecurityManager is
renamed to `reset()` and made public.
* The static references inside nRF5xGap, nRF5xGattClient, nRF5xGattServer and
nRF5xSecurityManager to objects of their own class are moved to nRF5xn.
* The static getInstance accessors in nRF5xGap, nRF5xGattClient,
nRF5xGattServer and nRF5xSecurityManager are removed and their functionality is
moved to the implemented virtual accessors in nRF5xn i.e. getGap(),
getGattClient, etc.
* A static function Instance is added to nRF5xn class to make the transport
object accessible across the module.
2015-12-14 15:15:35 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Accessors to GATT Client. This function checks whether a GattClient
|
|
|
|
* object was previously instantiated. If such object does not exist, then
|
|
|
|
* it is created before returning.
|
|
|
|
*
|
|
|
|
* @return A reference to GattClient.
|
|
|
|
*/
|
2015-06-03 12:53:05 +00:00
|
|
|
virtual GattClient &getGattClient() {
|
Modify shutdown due to BLE API change
The module is updated to comply with the changes to BLE API regarding correct
shutdown functionality. The following changes are introduced to ble-nrf51822:
* Calls to the old static function shutdown in Gap, GattClient, GattServer and
SecurityManager are removed.
* The cleanup function in Gap, GattClient, GattServer and SecurityManager is
renamed to `reset()` and made public.
* The static references inside nRF5xGap, nRF5xGattClient, nRF5xGattServer and
nRF5xSecurityManager to objects of their own class are moved to nRF5xn.
* The static getInstance accessors in nRF5xGap, nRF5xGattClient,
nRF5xGattServer and nRF5xSecurityManager are removed and their functionality is
moved to the implemented virtual accessors in nRF5xn i.e. getGap(),
getGattClient, etc.
* A static function Instance is added to nRF5xn class to make the transport
object accessible across the module.
2015-12-14 15:15:35 +00:00
|
|
|
if (gattClientInstance == NULL) {
|
|
|
|
gattClientInstance = new nRF5xGattClient();
|
|
|
|
}
|
|
|
|
return *gattClientInstance;
|
2015-06-19 07:28:35 +00:00
|
|
|
}
|
Modify shutdown due to BLE API change
The module is updated to comply with the changes to BLE API regarding correct
shutdown functionality. The following changes are introduced to ble-nrf51822:
* Calls to the old static function shutdown in Gap, GattClient, GattServer and
SecurityManager are removed.
* The cleanup function in Gap, GattClient, GattServer and SecurityManager is
renamed to `reset()` and made public.
* The static references inside nRF5xGap, nRF5xGattClient, nRF5xGattServer and
nRF5xSecurityManager to objects of their own class are moved to nRF5xn.
* The static getInstance accessors in nRF5xGap, nRF5xGattClient,
nRF5xGattServer and nRF5xSecurityManager are removed and their functionality is
moved to the implemented virtual accessors in nRF5xn i.e. getGap(),
getGattClient, etc.
* A static function Instance is added to nRF5xn class to make the transport
object accessible across the module.
2015-12-14 15:15:35 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Accessors to Security Manager. This function checks whether a SecurityManager
|
|
|
|
* object was previously instantiated. If such object does not exist, then
|
|
|
|
* it is created before returning.
|
|
|
|
*
|
|
|
|
* @return A reference to GattServer.
|
|
|
|
*/
|
2015-06-19 07:28:35 +00:00
|
|
|
virtual SecurityManager &getSecurityManager() {
|
Modify shutdown due to BLE API change
The module is updated to comply with the changes to BLE API regarding correct
shutdown functionality. The following changes are introduced to ble-nrf51822:
* Calls to the old static function shutdown in Gap, GattClient, GattServer and
SecurityManager are removed.
* The cleanup function in Gap, GattClient, GattServer and SecurityManager is
renamed to `reset()` and made public.
* The static references inside nRF5xGap, nRF5xGattClient, nRF5xGattServer and
nRF5xSecurityManager to objects of their own class are moved to nRF5xn.
* The static getInstance accessors in nRF5xGap, nRF5xGattClient,
nRF5xGattServer and nRF5xSecurityManager are removed and their functionality is
moved to the implemented virtual accessors in nRF5xn i.e. getGap(),
getGattClient, etc.
* A static function Instance is added to nRF5xn class to make the transport
object accessible across the module.
2015-12-14 15:15:35 +00:00
|
|
|
if (securityManagerInstance == NULL) {
|
|
|
|
securityManagerInstance = new nRF5xSecurityManager();
|
|
|
|
}
|
|
|
|
return *securityManagerInstance;
|
2015-05-07 12:14:25 +00:00
|
|
|
}
|
Modify shutdown due to BLE API change
The module is updated to comply with the changes to BLE API regarding correct
shutdown functionality. The following changes are introduced to ble-nrf51822:
* Calls to the old static function shutdown in Gap, GattClient, GattServer and
SecurityManager are removed.
* The cleanup function in Gap, GattClient, GattServer and SecurityManager is
renamed to `reset()` and made public.
* The static references inside nRF5xGap, nRF5xGattClient, nRF5xGattServer and
nRF5xSecurityManager to objects of their own class are moved to nRF5xn.
* The static getInstance accessors in nRF5xGap, nRF5xGattClient,
nRF5xGattServer and nRF5xSecurityManager are removed and their functionality is
moved to the implemented virtual accessors in nRF5xn i.e. getGap(),
getGattClient, etc.
* A static function Instance is added to nRF5xn class to make the transport
object accessible across the module.
2015-12-14 15:15:35 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Accessors to GAP. This function checks whether gapInstance points to an
|
|
|
|
* object. If if does not, then the gapInstance is updated to
|
|
|
|
* &_getInstance before returning.
|
|
|
|
*
|
|
|
|
* @return A const reference to GattServer.
|
|
|
|
*
|
|
|
|
* @note Unlike the GattClient, GattServer and SecurityManager, Gap is
|
|
|
|
* always needed in a BLE application. Therefore it is allocated
|
|
|
|
* statically.
|
|
|
|
*
|
|
|
|
* @note The accessor is able to modify the object's state because the
|
|
|
|
* internal pointer has been declared mutable.
|
|
|
|
*/
|
|
|
|
virtual const Gap &getGap() const {
|
|
|
|
if (gapInstance == NULL) {
|
|
|
|
gapInstance = &_gapInstance;
|
|
|
|
}
|
|
|
|
return *gapInstance;
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Accessors to GATT Server. This function checks whether a GattServer
|
|
|
|
* object was previously instantiated. If such object does not exist, then
|
|
|
|
* it is created before returning.
|
|
|
|
*
|
|
|
|
* @return A const reference to GattServer.
|
|
|
|
*
|
|
|
|
* @note The accessor is able to modify the object's state because the
|
|
|
|
* internal pointer has been declared mutable.
|
|
|
|
*/
|
|
|
|
virtual const GattServer &getGattServer() const {
|
|
|
|
if (gattServerInstance == NULL) {
|
|
|
|
gattServerInstance = new nRF5xGattServer();
|
|
|
|
}
|
|
|
|
return *gattServerInstance;
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Accessors to Security Manager. This function checks whether a SecurityManager
|
|
|
|
* object was previously instantiated. If such object does not exist, then
|
|
|
|
* it is created before returning.
|
|
|
|
*
|
|
|
|
* @return A const reference to GattServer.
|
|
|
|
*
|
|
|
|
* @note The accessor is able to modify the object's state because the
|
|
|
|
* internal pointer has been declared mutable.
|
|
|
|
*/
|
|
|
|
virtual const SecurityManager &getSecurityManager() const {
|
|
|
|
if (securityManagerInstance == NULL) {
|
|
|
|
securityManagerInstance = new nRF5xSecurityManager();
|
|
|
|
}
|
|
|
|
return *securityManagerInstance;
|
|
|
|
}
|
|
|
|
|
2015-07-06 13:17:22 +00:00
|
|
|
virtual void waitForEvent(void);
|
2015-10-28 14:05:27 +00:00
|
|
|
|
Modify shutdown due to BLE API change
The module is updated to comply with the changes to BLE API regarding correct
shutdown functionality. The following changes are introduced to ble-nrf51822:
* Calls to the old static function shutdown in Gap, GattClient, GattServer and
SecurityManager are removed.
* The cleanup function in Gap, GattClient, GattServer and SecurityManager is
renamed to `reset()` and made public.
* The static references inside nRF5xGap, nRF5xGattClient, nRF5xGattServer and
nRF5xSecurityManager to objects of their own class are moved to nRF5xn.
* The static getInstance accessors in nRF5xGap, nRF5xGattClient,
nRF5xGattServer and nRF5xSecurityManager are removed and their functionality is
moved to the implemented virtual accessors in nRF5xn i.e. getGap(),
getGattClient, etc.
* A static function Instance is added to nRF5xn class to make the transport
object accessible across the module.
2015-12-14 15:15:35 +00:00
|
|
|
public:
|
|
|
|
static nRF5xn& Instance(BLE::InstanceID_t instanceId);
|
|
|
|
|
2015-10-28 14:05:27 +00:00
|
|
|
private:
|
|
|
|
bool initialized;
|
|
|
|
BLE::InstanceID_t instanceID;
|
Modify shutdown due to BLE API change
The module is updated to comply with the changes to BLE API regarding correct
shutdown functionality. The following changes are introduced to ble-nrf51822:
* Calls to the old static function shutdown in Gap, GattClient, GattServer and
SecurityManager are removed.
* The cleanup function in Gap, GattClient, GattServer and SecurityManager is
renamed to `reset()` and made public.
* The static references inside nRF5xGap, nRF5xGattClient, nRF5xGattServer and
nRF5xSecurityManager to objects of their own class are moved to nRF5xn.
* The static getInstance accessors in nRF5xGap, nRF5xGattClient,
nRF5xGattServer and nRF5xSecurityManager are removed and their functionality is
moved to the implemented virtual accessors in nRF5xn i.e. getGap(),
getGattClient, etc.
* A static function Instance is added to nRF5xn class to make the transport
object accessible across the module.
2015-12-14 15:15:35 +00:00
|
|
|
|
|
|
|
private:
|
2015-12-15 13:16:05 +00:00
|
|
|
mutable nRF5xGap _gapInstance; /**< Gap instance whose reference is returned from a call to
|
|
|
|
* getGap(). Unlike the GattClient, GattServer and
|
|
|
|
* SecurityManager, Gap is always needed in a BLE application.
|
|
|
|
* Therefore it is allocated statically. */
|
Modify shutdown due to BLE API change
The module is updated to comply with the changes to BLE API regarding correct
shutdown functionality. The following changes are introduced to ble-nrf51822:
* Calls to the old static function shutdown in Gap, GattClient, GattServer and
SecurityManager are removed.
* The cleanup function in Gap, GattClient, GattServer and SecurityManager is
renamed to `reset()` and made public.
* The static references inside nRF5xGap, nRF5xGattClient, nRF5xGattServer and
nRF5xSecurityManager to objects of their own class are moved to nRF5xn.
* The static getInstance accessors in nRF5xGap, nRF5xGattClient,
nRF5xGattServer and nRF5xSecurityManager are removed and their functionality is
moved to the implemented virtual accessors in nRF5xn i.e. getGap(),
getGattClient, etc.
* A static function Instance is added to nRF5xn class to make the transport
object accessible across the module.
2015-12-14 15:15:35 +00:00
|
|
|
|
|
|
|
private:
|
|
|
|
mutable nRF5xGap *gapInstance; /**< Pointer to the Gap object instance.
|
|
|
|
* If NULL, then Gap has not been initialized.
|
|
|
|
* The pointer has been declared as 'mutable' so that
|
|
|
|
* it can be assigned inside a 'const' function. */
|
|
|
|
mutable nRF5xGattServer *gattServerInstance; /**< Pointer to the GattServer object instance.
|
|
|
|
* If NULL, then GattServer has not been initialized.
|
|
|
|
* The pointer has been declared as 'mutable' so that
|
|
|
|
* it can be assigned inside a 'const' function. */
|
|
|
|
mutable nRF5xGattClient *gattClientInstance; /**< Pointer to the GattClient object instance.
|
|
|
|
* If NULL, then GattClient has not been initialized.
|
|
|
|
* The pointer has been declared as 'mutable' so that
|
|
|
|
* it can be assigned inside a 'const' function. */
|
|
|
|
mutable nRF5xSecurityManager *securityManagerInstance; /**< Pointer to the SecurityManager object instance.
|
|
|
|
* If NULL, then SecurityManager has not been initialized.
|
|
|
|
* The pointer has been declared as 'mutable' so that
|
|
|
|
* it can be assigned inside a 'const' function. */
|
2014-07-30 10:36:32 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif
|