1 /**
2 * Copyright (c) 2019 Oticon A/S
3 *
4 * SPDX-License-Identifier: Apache-2.0
5 */
6 /**
7 * @brief Service D
8 *
9 * This code is auto-generated from the Excel Workbook
10 * 'GATT_Test_Databases.xlsm' Sheet: 'Large Database 2'
11 */
12 #include <zephyr/sys/byteorder.h>
13 #include <zephyr/sys/printk.h>
14
15 #include <zephyr/bluetooth/gatt.h>
16
17 #include "gatt_macs.h"
18
19 extern struct bt_gatt_attr service_b_1_2_attrs[];
20
21 /**
22 * @brief UUID for the Service D
23 */
24 #define BT_UUID_SERVICE_D BT_UUID_DECLARE_16(0xa00d)
25
26 /**
27 * @brief UUID for the Value V11 (128-bit UUID) Characteristic
28 */
29 #define BT_UUID_VALUE_V11__128_BIT_UUID BT_UUID_DECLARE_128( \
30 0xef, 0xcd, 0xab, 0x89, 0x67, 0x45, 0x23, 0x01, \
31 0x00, 0x00, 0x00, 0x00, 0x0b, 0xb0, 0x00, 0x00)
32
33 /**
34 * @brief UUID for the Value V12 Characteristic
35 */
36 #define BT_UUID_VALUE_V12 BT_UUID_DECLARE_16(0xb00c)
37
38 static uint8_t value_v11__128_bit_uuid_value = 0x0B;
39 static uint8_t value_v12_value = 0x0C;
40
41 /**
42 * @brief Attribute read call back for the Value V11 (128-bit UUID) attribute
43 *
44 * @param conn The connection that is requesting to read
45 * @param attr The attribute that's being read
46 * @param buf Buffer to place the read result in
47 * @param len Length of data to read
48 * @param offset Offset to start reading from
49 *
50 * @return Number of bytes read, or in case of an error - BT_GATT_ERR()
51 * with a specific ATT error code.
52 */
read_value_v11__128_bit_uuid(struct bt_conn * conn,const struct bt_gatt_attr * attr,void * buf,uint16_t len,uint16_t offset)53 static ssize_t read_value_v11__128_bit_uuid(struct bt_conn *conn,
54 const struct bt_gatt_attr *attr,
55 void *buf, uint16_t len, uint16_t offset)
56 {
57 const uint8_t *value = attr->user_data;
58
59 return bt_gatt_attr_read(conn, attr, buf, len, offset, value,
60 sizeof(value_v11__128_bit_uuid_value));
61 }
62
63 /**
64 * @brief Attribute read call back for the Value V12 attribute
65 *
66 * @param conn The connection that is requesting to read
67 * @param attr The attribute that's being read
68 * @param buf Buffer to place the read result in
69 * @param len Length of data to read
70 * @param offset Offset to start reading from
71 *
72 * @return Number of bytes read, or in case of an error - BT_GATT_ERR()
73 * with a specific ATT error code.
74 */
read_value_v12(struct bt_conn * conn,const struct bt_gatt_attr * attr,void * buf,uint16_t len,uint16_t offset)75 static ssize_t read_value_v12(struct bt_conn *conn,
76 const struct bt_gatt_attr *attr, void *buf,
77 uint16_t len, uint16_t offset)
78 {
79 const uint8_t *value = attr->user_data;
80
81 return bt_gatt_attr_read(conn, attr, buf, len, offset, value,
82 sizeof(value_v12_value));
83 }
84
85 struct bt_gatt_attr service_d_2_attrs[] = {
86 BT_GATT_H_SECONDARY_SERVICE(BT_UUID_SERVICE_D, 0x40),
87 BT_GATT_H_INCLUDE_SERVICE(service_b_1_2_attrs, 0x41),
88 BT_GATT_H_CHARACTERISTIC(BT_UUID_VALUE_V11__128_BIT_UUID,
89 BT_GATT_CHRC_READ,
90 BT_GATT_PERM_READ,
91 read_value_v11__128_bit_uuid, NULL,
92 &value_v11__128_bit_uuid_value, 0x42),
93 BT_GATT_H_CHARACTERISTIC(BT_UUID_VALUE_V12,
94 BT_GATT_CHRC_READ,
95 BT_GATT_PERM_READ,
96 read_value_v12, NULL, &value_v12_value, 0x44)
97 };
98
99 static struct bt_gatt_service service_d_2_svc =
100 BT_GATT_SERVICE(service_d_2_attrs);
101
102 /**
103 * @brief Register the Service D and all its Characteristics...
104 */
service_d_2_init(void)105 void service_d_2_init(void)
106 {
107 bt_gatt_service_register(&service_d_2_svc);
108 }
109
110 /**
111 * @brief Un-Register the Service D and all its Characteristics...
112 */
service_d_2_remove(void)113 void service_d_2_remove(void)
114 {
115 bt_gatt_service_unregister(&service_d_2_svc);
116 }
117