wersion 1.9
Fork of BLE_API by
ble/blecommon.h@854:ad4ae73c2b5a, 2015-11-02 (annotated)
- Committer:
- rgrover1
- Date:
- Mon Nov 02 09:09:06 2015 +0000
- Revision:
- 854:ad4ae73c2b5a
- Parent:
- 737:79d95f9b93be
- Child:
- 857:7f578be2d01d
Synchronized with git rev 918af4fb
Author: Rohit Grover
Major change:
- There's a new type: BLE::InitializationCompleteCallback_t
- init() now takes a completion callback. This is an optional parameter, if no callback is setup the application can still determine the status of initialization using BLE::hasInitialized() (see below).
- There's a new API: BLEInstanceBase::hasInitialized() which transports need to implement.
- BLEInstanceBase.h is no longer included from BLE.h. We use a forward declaration of BLEInstanceBase instead. This is required us to move implementations of BLE methods out of the header and into BLE.cpp.
- There's a new API: BLE::getInstanceID(), which simply returns the ID of an instance.
- There are new error types around initialization.
Who changed what in which revision?
User | Revision | Line number | New contents of line |
---|---|---|---|
rgrover1 | 710:b2e1a2660ec2 | 1 | /* mbed Microcontroller Library |
rgrover1 | 710:b2e1a2660ec2 | 2 | * Copyright (c) 2006-2013 ARM Limited |
rgrover1 | 710:b2e1a2660ec2 | 3 | * |
rgrover1 | 710:b2e1a2660ec2 | 4 | * Licensed under the Apache License, Version 2.0 (the "License"); |
rgrover1 | 710:b2e1a2660ec2 | 5 | * you may not use this file except in compliance with the License. |
rgrover1 | 710:b2e1a2660ec2 | 6 | * You may obtain a copy of the License at |
rgrover1 | 710:b2e1a2660ec2 | 7 | * |
rgrover1 | 710:b2e1a2660ec2 | 8 | * http://www.apache.org/licenses/LICENSE-2.0 |
rgrover1 | 710:b2e1a2660ec2 | 9 | * |
rgrover1 | 710:b2e1a2660ec2 | 10 | * Unless required by applicable law or agreed to in writing, software |
rgrover1 | 710:b2e1a2660ec2 | 11 | * distributed under the License is distributed on an "AS IS" BASIS, |
rgrover1 | 710:b2e1a2660ec2 | 12 | * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
rgrover1 | 710:b2e1a2660ec2 | 13 | * See the License for the specific language governing permissions and |
rgrover1 | 710:b2e1a2660ec2 | 14 | * limitations under the License. |
rgrover1 | 710:b2e1a2660ec2 | 15 | */ |
rgrover1 | 710:b2e1a2660ec2 | 16 | |
rgrover1 | 710:b2e1a2660ec2 | 17 | #ifndef __BLE_COMMON_H__ |
rgrover1 | 710:b2e1a2660ec2 | 18 | #define __BLE_COMMON_H__ |
rgrover1 | 710:b2e1a2660ec2 | 19 | |
rgrover1 | 710:b2e1a2660ec2 | 20 | #ifdef __cplusplus |
rgrover1 | 710:b2e1a2660ec2 | 21 | extern "C" { |
rgrover1 | 710:b2e1a2660ec2 | 22 | #endif |
rgrover1 | 710:b2e1a2660ec2 | 23 | |
rgrover1 | 710:b2e1a2660ec2 | 24 | |
rgrover1 | 710:b2e1a2660ec2 | 25 | /** @defgroup BLE_UUID_VALUES Assigned Values for BLE UUIDs |
rgrover1 | 710:b2e1a2660ec2 | 26 | * @{ */ |
rgrover1 | 710:b2e1a2660ec2 | 27 | /* Generic UUIDs, applicable to all services */ |
rgrover1 | 710:b2e1a2660ec2 | 28 | enum { |
rgrover1 | 710:b2e1a2660ec2 | 29 | BLE_UUID_UNKNOWN = 0x0000, /**< Reserved UUID. */ |
rgrover1 | 710:b2e1a2660ec2 | 30 | BLE_UUID_SERVICE_PRIMARY = 0x2800, /**< Primary Service. */ |
rgrover1 | 710:b2e1a2660ec2 | 31 | BLE_UUID_SERVICE_SECONDARY = 0x2801, /**< Secondary Service. */ |
rgrover1 | 710:b2e1a2660ec2 | 32 | BLE_UUID_SERVICE_INCLUDE = 0x2802, /**< Include. */ |
rgrover1 | 710:b2e1a2660ec2 | 33 | BLE_UUID_CHARACTERISTIC = 0x2803, /**< Characteristic. */ |
rgrover1 | 710:b2e1a2660ec2 | 34 | BLE_UUID_DESCRIPTOR_CHAR_EXT_PROP = 0x2900, /**< Characteristic Extended Properties Descriptor. */ |
rgrover1 | 710:b2e1a2660ec2 | 35 | BLE_UUID_DESCRIPTOR_CHAR_USER_DESC = 0x2901, /**< Characteristic User Description Descriptor. */ |
rgrover1 | 710:b2e1a2660ec2 | 36 | BLE_UUID_DESCRIPTOR_CLIENT_CHAR_CONFIG = 0x2902, /**< Client Characteristic Configuration Descriptor. */ |
rgrover1 | 710:b2e1a2660ec2 | 37 | BLE_UUID_DESCRIPTOR_SERVER_CHAR_CONFIG = 0x2903, /**< Server Characteristic Configuration Descriptor. */ |
rgrover1 | 710:b2e1a2660ec2 | 38 | BLE_UUID_DESCRIPTOR_CHAR_PRESENTATION_FORMAT = 0x2904, /**< Characteristic Presentation Format Descriptor. */ |
rgrover1 | 710:b2e1a2660ec2 | 39 | BLE_UUID_DESCRIPTOR_CHAR_AGGREGATE_FORMAT = 0x2905, /**< Characteristic Aggregate Format Descriptor. */ |
rgrover1 | 710:b2e1a2660ec2 | 40 | |
rgrover1 | 710:b2e1a2660ec2 | 41 | /* GATT specific UUIDs */ |
rgrover1 | 710:b2e1a2660ec2 | 42 | BLE_UUID_GATT = 0x1801, /**< Generic Attribute Profile. */ |
rgrover1 | 710:b2e1a2660ec2 | 43 | BLE_UUID_GATT_CHARACTERISTIC_SERVICE_CHANGED = 0x2A05, /**< Service Changed Characteristic. */ |
rgrover1 | 710:b2e1a2660ec2 | 44 | |
rgrover1 | 710:b2e1a2660ec2 | 45 | /* GAP specific UUIDs */ |
rgrover1 | 710:b2e1a2660ec2 | 46 | BLE_UUID_GAP = 0x1800, /**< Generic Access Profile. */ |
rgrover1 | 710:b2e1a2660ec2 | 47 | BLE_UUID_GAP_CHARACTERISTIC_DEVICE_NAME = 0x2A00, /**< Device Name Characteristic. */ |
rgrover1 | 710:b2e1a2660ec2 | 48 | BLE_UUID_GAP_CHARACTERISTIC_APPEARANCE = 0x2A01, /**< Appearance Characteristic. */ |
rgrover1 | 710:b2e1a2660ec2 | 49 | BLE_UUID_GAP_CHARACTERISTIC_PPF = 0x2A02, /**< Peripheral Privacy Flag Characteristic. */ |
rgrover1 | 710:b2e1a2660ec2 | 50 | BLE_UUID_GAP_CHARACTERISTIC_RECONN_ADDR = 0x2A03, /**< Reconnection Address Characteristic. */ |
rgrover1 | 710:b2e1a2660ec2 | 51 | BLE_UUID_GAP_CHARACTERISTIC_PPCP = 0x2A04, /**< Peripheral Preferred Connection Parameters Characteristic. */ |
rgrover1 | 710:b2e1a2660ec2 | 52 | }; |
rgrover1 | 710:b2e1a2660ec2 | 53 | /** @} */ |
rgrover1 | 710:b2e1a2660ec2 | 54 | |
rgrover1 | 710:b2e1a2660ec2 | 55 | /** @defgroup BLE_APPEARANCES Bluetooth Appearance values |
rgrover1 | 710:b2e1a2660ec2 | 56 | * @note Retrieved from http://developer.bluetooth.org/gatt/characteristics/Pages/CharacteristicViewer.aspx?u=org.bluetooth.characteristic.gap.appearance.xml |
rgrover1 | 710:b2e1a2660ec2 | 57 | * @{ */ |
rgrover1 | 710:b2e1a2660ec2 | 58 | enum { |
rgrover1 | 710:b2e1a2660ec2 | 59 | BLE_APPEARANCE_UNKNOWN = 0, /**< Unknown. */ |
rgrover1 | 710:b2e1a2660ec2 | 60 | BLE_APPEARANCE_GENERIC_PHONE = 64, /**< Generic Phone. */ |
rgrover1 | 710:b2e1a2660ec2 | 61 | BLE_APPEARANCE_GENERIC_COMPUTER = 128, /**< Generic Computer. */ |
rgrover1 | 710:b2e1a2660ec2 | 62 | BLE_APPEARANCE_GENERIC_WATCH = 192, /**< Generic Watch. */ |
rgrover1 | 710:b2e1a2660ec2 | 63 | BLE_APPEARANCE_WATCH_SPORTS_WATCH = 193, /**< Watch: Sports Watch. */ |
rgrover1 | 710:b2e1a2660ec2 | 64 | BLE_APPEARANCE_GENERIC_CLOCK = 256, /**< Generic Clock. */ |
rgrover1 | 710:b2e1a2660ec2 | 65 | BLE_APPEARANCE_GENERIC_DISPLAY = 320, /**< Generic Display. */ |
rgrover1 | 710:b2e1a2660ec2 | 66 | BLE_APPEARANCE_GENERIC_REMOTE_CONTROL = 384, /**< Generic Remote Control. */ |
rgrover1 | 710:b2e1a2660ec2 | 67 | BLE_APPEARANCE_GENERIC_EYE_GLASSES = 448, /**< Generic Eye-glasses. */ |
rgrover1 | 710:b2e1a2660ec2 | 68 | BLE_APPEARANCE_GENERIC_TAG = 512, /**< Generic Tag. */ |
rgrover1 | 710:b2e1a2660ec2 | 69 | BLE_APPEARANCE_GENERIC_KEYRING = 576, /**< Generic Keyring. */ |
rgrover1 | 710:b2e1a2660ec2 | 70 | BLE_APPEARANCE_GENERIC_MEDIA_PLAYER = 640, /**< Generic Media Player. */ |
rgrover1 | 710:b2e1a2660ec2 | 71 | BLE_APPEARANCE_GENERIC_BARCODE_SCANNER = 704, /**< Generic Barcode Scanner. */ |
rgrover1 | 710:b2e1a2660ec2 | 72 | BLE_APPEARANCE_GENERIC_THERMOMETER = 768, /**< Generic Thermometer. */ |
rgrover1 | 710:b2e1a2660ec2 | 73 | BLE_APPEARANCE_THERMOMETER_EAR = 769, /**< Thermometer: Ear. */ |
rgrover1 | 710:b2e1a2660ec2 | 74 | BLE_APPEARANCE_GENERIC_HEART_RATE_SENSOR = 832, /**< Generic Heart rate Sensor. */ |
rgrover1 | 710:b2e1a2660ec2 | 75 | BLE_APPEARANCE_HEART_RATE_SENSOR_HEART_RATE_BELT = 833, /**< Heart Rate Sensor: Heart Rate Belt. */ |
rgrover1 | 710:b2e1a2660ec2 | 76 | BLE_APPEARANCE_GENERIC_BLOOD_PRESSURE = 896, /**< Generic Blood Pressure. */ |
rgrover1 | 710:b2e1a2660ec2 | 77 | BLE_APPEARANCE_BLOOD_PRESSURE_ARM = 897, /**< Blood Pressure: Arm. */ |
rgrover1 | 710:b2e1a2660ec2 | 78 | BLE_APPEARANCE_BLOOD_PRESSURE_WRIST = 898, /**< Blood Pressure: Wrist. */ |
rgrover1 | 710:b2e1a2660ec2 | 79 | BLE_APPEARANCE_GENERIC_HID = 960, /**< Human Interface Device (HID). */ |
rgrover1 | 710:b2e1a2660ec2 | 80 | BLE_APPEARANCE_HID_KEYBOARD = 961, /**< Keyboard (HID Subtype). */ |
rgrover1 | 710:b2e1a2660ec2 | 81 | BLE_APPEARANCE_HID_MOUSE = 962, /**< Mouse (HID Subtype). */ |
rgrover1 | 710:b2e1a2660ec2 | 82 | BLE_APPEARANCE_HID_JOYSTICK = 963, /**< Joystiq (HID Subtype). */ |
rgrover1 | 710:b2e1a2660ec2 | 83 | BLE_APPEARANCE_HID_GAMEPAD = 964, /**< Gamepad (HID Subtype). */ |
rgrover1 | 710:b2e1a2660ec2 | 84 | BLE_APPEARANCE_HID_DIGITIZERSUBTYPE = 965, /**< Digitizer Tablet (HID Subtype). */ |
rgrover1 | 710:b2e1a2660ec2 | 85 | BLE_APPEARANCE_HID_CARD_READER = 966, /**< Card Reader (HID Subtype). */ |
rgrover1 | 710:b2e1a2660ec2 | 86 | BLE_APPEARANCE_HID_DIGITAL_PEN = 967, /**< Digital Pen (HID Subtype). */ |
rgrover1 | 710:b2e1a2660ec2 | 87 | BLE_APPEARANCE_HID_BARCODE = 968, /**< Barcode Scanner (HID Subtype). */ |
rgrover1 | 710:b2e1a2660ec2 | 88 | BLE_APPEARANCE_GENERIC_GLUCOSE_METER = 1024, /**< Generic Glucose Meter. */ |
rgrover1 | 710:b2e1a2660ec2 | 89 | BLE_APPEARANCE_GENERIC_RUNNING_WALKING_SENSOR = 1088, /**< Generic Running Walking Sensor. */ |
rgrover1 | 710:b2e1a2660ec2 | 90 | BLE_APPEARANCE_RUNNING_WALKING_SENSOR_IN_SHOE = 1089, /**< Running Walking Sensor: In-Shoe. */ |
rgrover1 | 710:b2e1a2660ec2 | 91 | BLE_APPEARANCE_RUNNING_WALKING_SENSOR_ON_SHOE = 1090, /**< Running Walking Sensor: On-Shoe. */ |
rgrover1 | 710:b2e1a2660ec2 | 92 | BLE_APPEARANCE_RUNNING_WALKING_SENSOR_ON_HIP = 1091, /**< Running Walking Sensor: On-Hip. */ |
rgrover1 | 710:b2e1a2660ec2 | 93 | BLE_APPEARANCE_GENERIC_CYCLING = 1152, /**< Generic Cycling. */ |
rgrover1 | 710:b2e1a2660ec2 | 94 | BLE_APPEARANCE_CYCLING_CYCLING_COMPUTER = 1153, /**< Cycling: Cycling Computer. */ |
rgrover1 | 710:b2e1a2660ec2 | 95 | BLE_APPEARANCE_CYCLING_SPEED_SENSOR = 1154, /**< Cycling: Speed Sensor. */ |
rgrover1 | 710:b2e1a2660ec2 | 96 | BLE_APPEARANCE_CYCLING_CADENCE_SENSOR = 1155, /**< Cycling: Cadence Sensor. */ |
rgrover1 | 710:b2e1a2660ec2 | 97 | BLE_APPEARANCE_CYCLING_POWER_SENSOR = 1156, /**< Cycling: Power Sensor. */ |
rgrover1 | 710:b2e1a2660ec2 | 98 | BLE_APPEARANCE_CYCLING_SPEED_CADENCE_SENSOR = 1157, /**< Cycling: Speed and Cadence Sensor. */ |
rgrover1 | 710:b2e1a2660ec2 | 99 | BLE_APPEARANCE_GENERIC_PULSE_OXIMETER = 3136, /**< Generic Pulse Oximeter. */ |
rgrover1 | 710:b2e1a2660ec2 | 100 | BLE_APPEARANCE_PULSE_OXIMETER_FINGERTIP = 3137, /**< Fingertip (Pulse Oximeter subtype). */ |
rgrover1 | 710:b2e1a2660ec2 | 101 | BLE_APPEARANCE_PULSE_OXIMETER_WRIST_WORN = 3138, /**< Wrist Worn(Pulse Oximeter subtype). */ |
rgrover1 | 710:b2e1a2660ec2 | 102 | BLE_APPEARANCE_GENERIC_WEIGHT_SCALE = 3200, /**< Generic Weight Scale. */ |
rgrover1 | 710:b2e1a2660ec2 | 103 | BLE_APPEARANCE_GENERIC_OUTDOOR_SPORTS_ACT = 5184, /**< Generic Outdoor Sports Activity. */ |
rgrover1 | 710:b2e1a2660ec2 | 104 | BLE_APPEARANCE_OUTDOOR_SPORTS_ACT_LOC_DISP = 5185, /**< Location Display Device (Outdoor Sports Activity subtype). */ |
rgrover1 | 710:b2e1a2660ec2 | 105 | BLE_APPEARANCE_OUTDOOR_SPORTS_ACT_LOC_AND_NAV_DISP = 5186, /**< Location and Navigation Display Device (Outdoor Sports Activity subtype). */ |
rgrover1 | 710:b2e1a2660ec2 | 106 | BLE_APPEARANCE_OUTDOOR_SPORTS_ACT_LOC_POD = 5187, /**< Location Pod (Outdoor Sports Activity subtype). */ |
rgrover1 | 710:b2e1a2660ec2 | 107 | BLE_APPEARANCE_OUTDOOR_SPORTS_ACT_LOC_AND_NAV_POD = 5188, /**< Location and Navigation Pod (Outdoor Sports Activity subtype). */ |
rgrover1 | 710:b2e1a2660ec2 | 108 | }; |
rgrover1 | 710:b2e1a2660ec2 | 109 | /** @} */ |
rgrover1 | 710:b2e1a2660ec2 | 110 | |
rgrover1 | 710:b2e1a2660ec2 | 111 | /**************************************************************************/ |
rgrover1 | 710:b2e1a2660ec2 | 112 | /*! |
rgrover1 | 710:b2e1a2660ec2 | 113 | \brief Error codes for the BLE API |
rgrover1 | 710:b2e1a2660ec2 | 114 | */ |
rgrover1 | 710:b2e1a2660ec2 | 115 | /**************************************************************************/ |
rgrover1 | 710:b2e1a2660ec2 | 116 | enum ble_error_t { |
rgrover1 | 854:ad4ae73c2b5a | 117 | BLE_ERROR_NONE = 0, /**< No error */ |
rgrover1 | 854:ad4ae73c2b5a | 118 | BLE_ERROR_BUFFER_OVERFLOW = 1, /**< The requested action would cause a buffer overflow and has been aborted */ |
rgrover1 | 854:ad4ae73c2b5a | 119 | BLE_ERROR_NOT_IMPLEMENTED = 2, /**< Requested a feature that isn't yet implement or isn't supported by the target HW */ |
rgrover1 | 854:ad4ae73c2b5a | 120 | BLE_ERROR_PARAM_OUT_OF_RANGE = 3, /**< One of the supplied parameters is outside the valid range */ |
rgrover1 | 854:ad4ae73c2b5a | 121 | BLE_ERROR_INVALID_PARAM = 4, /**< One of the supplied parameters is invalid */ |
rgrover1 | 854:ad4ae73c2b5a | 122 | BLE_STACK_BUSY = 5, /**< The stack is busy */ |
rgrover1 | 854:ad4ae73c2b5a | 123 | BLE_ERROR_INVALID_STATE = 6, /**< Invalid state. */ |
rgrover1 | 854:ad4ae73c2b5a | 124 | BLE_ERROR_NO_MEM = 7, /**< Out of Memory */ |
rgrover1 | 854:ad4ae73c2b5a | 125 | BLE_ERROR_OPERATION_NOT_PERMITTED = 8, |
rgrover1 | 854:ad4ae73c2b5a | 126 | BLE_ERROR_INITIALIZATION_INCOMPLETE = 9, |
rgrover1 | 854:ad4ae73c2b5a | 127 | BLE_ERROR_ALREADY_INITIALIZED = 10, |
rgrover1 | 854:ad4ae73c2b5a | 128 | BLE_ERROR_UNSPECIFIED = 11, /**< Unknown error. */ |
rgrover1 | 710:b2e1a2660ec2 | 129 | }; |
rgrover1 | 710:b2e1a2660ec2 | 130 | |
rgrover1 | 728:997ba5e7b3b6 | 131 | /** @brief Default MTU size. */ |
rgrover1 | 728:997ba5e7b3b6 | 132 | static const unsigned BLE_GATT_MTU_SIZE_DEFAULT = 23; |
rgrover1 | 728:997ba5e7b3b6 | 133 | |
rgrover1 | 737:79d95f9b93be | 134 | enum HVXType_t { |
rgrover1 | 737:79d95f9b93be | 135 | BLE_HVX_NOTIFICATION = 0x01, /**< Handle Value Notification. */ |
rgrover1 | 737:79d95f9b93be | 136 | BLE_HVX_INDICATION = 0x02, /**< Handle Value Indication. */ |
rgrover1 | 737:79d95f9b93be | 137 | }; |
rgrover1 | 737:79d95f9b93be | 138 | |
rgrover1 | 710:b2e1a2660ec2 | 139 | #ifdef __cplusplus |
rgrover1 | 710:b2e1a2660ec2 | 140 | } |
rgrover1 | 710:b2e1a2660ec2 | 141 | #endif |
rgrover1 | 710:b2e1a2660ec2 | 142 | |
rgrover1 | 710:b2e1a2660ec2 | 143 | #endif // ifndef __BLE_COMMON_H__ |