Loading...
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 | /**
* Copyright (c) 2019 Oticon A/S
*
* SPDX-License-Identifier: Apache-2.0
*/
/**
* @brief Service B.3
*
* This code is auto-generated from the Excel Workbook
* 'GATT_Test_Databases.xlsm' Sheet: 'Large Database 2'
*/
#include <sys/byteorder.h>
#include <sys/printk.h>
#include <bluetooth/gatt.h>
#include "gatt_macs.h"
/** @def BT_UUID_SERVICE_B_3
* @brief UUID for the Service B.3
*/
#define BT_UUID_SERVICE_B_3 BT_UUID_DECLARE_16(0xa00b)
/** @def BT_UUID_VALUE_V6
* @brief UUID for the Value V6 Characteristic
*/
#define BT_UUID_VALUE_V6 BT_UUID_DECLARE_16(0xb006)
static uint8_t value_v6_value = 0x06;
static struct bt_gatt_indicate_params ind_params;
static bool value_v6_ntf_active;
static bool value_v6_ind_active;
/**
* @brief Attribute read call back for the Value V6 attribute
*
* @param conn The connection that is requesting to read
* @param attr The attribute that's being read
* @param buf Buffer to place the read result in
* @param len Length of data to read
* @param offset Offset to start reading from
*
* @return Number of bytes read, or in case of an error - BT_GATT_ERR()
* with a specific ATT error code.
*/
static ssize_t read_value_v6(struct bt_conn *conn,
const struct bt_gatt_attr *attr, void *buf,
uint16_t len, uint16_t offset)
{
const uint8_t *value = attr->user_data;
return bt_gatt_attr_read(conn, attr, buf, len, offset, value,
sizeof(value_v6_value));
}
/**
* @brief Attribute write call back for the Value V6 attribute
*
* @param conn The connection that is requesting to write
* @param attr The attribute that's being written
* @param buf Buffer with the data to write
* @param len Number of bytes in the buffer
* @param offset Offset to start writing from
* @param flags Flags (BT_GATT_WRITE_*)
*
* @return Number of bytes written, or in case of an error - BT_GATT_ERR()
* with a specific ATT error code.
*/
static ssize_t write_value_v6(struct bt_conn *conn,
const struct bt_gatt_attr *attr, const void *buf,
uint16_t len, uint16_t offset, uint8_t flags)
{
uint8_t *value = attr->user_data;
if (offset >= sizeof(value_v6_value))
return BT_GATT_ERR(BT_ATT_ERR_INVALID_OFFSET);
if (offset + len > sizeof(value_v6_value))
return BT_GATT_ERR(BT_ATT_ERR_INVALID_ATTRIBUTE_LEN);
memcpy(value + offset, buf, len);
return len;
}
/**
* @brief Descriptor configuration change call back for the Value V6 attribute
*
* @param attr The attribute whose descriptor configuration has changed
* @param value The new value of the descriptor configuration
*/
static void value_v6_ccc_cfg_changed(const struct bt_gatt_attr *attr,
uint16_t value)
{
value_v6_ntf_active = value == BT_GATT_CCC_NOTIFY;
value_v6_ind_active = value == BT_GATT_CCC_INDICATE;
}
static struct bt_gatt_attr service_b_3_2_attrs[] = {
BT_GATT_H_PRIMARY_SERVICE(BT_UUID_SERVICE_B_3, 0x70),
BT_GATT_H_CHARACTERISTIC(BT_UUID_VALUE_V6,
BT_GATT_CHRC_READ | BT_GATT_CHRC_WRITE_WITHOUT_RESP |
BT_GATT_CHRC_WRITE | BT_GATT_CHRC_NOTIFY |
BT_GATT_CHRC_INDICATE,
BT_GATT_PERM_READ | BT_GATT_PERM_WRITE,
read_value_v6, write_value_v6, &value_v6_value, 0x71),
BT_GATT_H_CCC(value_v6_ccc_cfg, value_v6_ccc_cfg_changed, 0x73)
};
static struct bt_gatt_service service_b_3_2_svc =
BT_GATT_SERVICE(service_b_3_2_attrs);
/**
* @brief Register the Service B.3 and all its Characteristics...
*/
void service_b_3_2_init(void)
{
bt_gatt_service_register(&service_b_3_2_svc);
}
/**
* @brief Un-Register the Service B.3 and all its Characteristics...
*/
void service_b_3_2_remove(void)
{
bt_gatt_service_unregister(&service_b_3_2_svc);
}
/**
* @brief Generate notification for 'Value V6' attribute, if notifications are
* enabled.
*/
void service_b_3_2_value_v6_notify(void)
{
if (!value_v6_ntf_active)
return;
bt_gatt_notify(NULL, &service_b_3_2_attrs[1], &value_v6_value,
sizeof(value_v6_value));
}
/**
* @brief Indication call back for 'Value V6' attribute
*
* @param conn The connection for which the indication was generated
* @param attr The attribute that generated the indication
* @param err The error code from the indicate attempt, 0 if no error or
* BT_GATT_ERR() with a specific ATT error code.
*/
static void value_v6_indicate_cb(struct bt_conn *conn,
struct bt_gatt_indicate_params *params,
uint8_t err)
{
printk("Indication for attribute 'Value V6' %s\n",
(err) ? "failed" : "succeded");
}
/**
* @brief Generate indication for 'Value V6' attribute, if indications are
* enabled.
*/
void service_b_3_2_value_v6_indicate(void)
{
if (!value_v6_ind_active)
return;
/*
* NOTE: Zephyr doesn't automatically bump up the attribute pointer for
* indications as it does for notifications.
*/
ind_params.attr = &service_b_3_2_attrs[2];
ind_params.func = value_v6_indicate_cb;
ind_params.destroy = NULL;
ind_params.data = &value_v6_value;
ind_params.len = sizeof(value_v6_value);
bt_gatt_indicate(NULL, &ind_params);
}
|