Select one of the symbols to view example projects that use it.
 
Outline
#define GATT_API_H
#include "common/bt_target.h"
#include "stack/gattdefs.h"
#include "stack/btm_ble_api.h"
#define GATT_SUCCESS
#define GATT_INVALID_HANDLE
#define GATT_READ_NOT_PERMIT
#define GATT_WRITE_NOT_PERMIT
#define GATT_INVALID_PDU
#define GATT_INSUF_AUTHENTICATION
#define GATT_REQ_NOT_SUPPORTED
#define GATT_INVALID_OFFSET
#define GATT_INSUF_AUTHORIZATION
#define GATT_PREPARE_Q_FULL
#define GATT_NOT_FOUND
#define GATT_NOT_LONG
#define GATT_INSUF_KEY_SIZE
#define GATT_INVALID_ATTR_LEN
#define GATT_ERR_UNLIKELY
#define GATT_INSUF_ENCRYPTION
#define GATT_UNSUPPORT_GRP_TYPE
#define GATT_INSUF_RESOURCE
#define GATT_DATABASE_OUT_OF_SYNC
#define GATT_VALUE_NOT_ALLOWED
#define GATT_NO_RESOURCES
#define GATT_INTERNAL_ERROR
#define GATT_WRONG_STATE
#define GATT_DB_FULL
#define GATT_BUSY
#define GATT_ERROR
#define GATT_CMD_STARTED
#define GATT_ILLEGAL_PARAMETER
#define GATT_PENDING
#define GATT_AUTH_FAIL
#define GATT_MORE
#define GATT_INVALID_CFG
#define GATT_SERVICE_STARTED
#define GATT_ENCRYPED_MITM
#define GATT_ENCRYPED_NO_MITM
#define GATT_NOT_ENCRYPTED
#define GATT_CONGESTED
#define GATT_DUP_REG
#define GATT_ALREADY_OPEN
#define GATT_CANCEL
#define GATT_STACK_RSP
#define GATT_APP_RSP
#define GATT_UNKNOWN_ERROR
#define GATT_CCC_CFG_ERR
#define GATT_PRC_IN_PROGRESS
#define GATT_OUT_OF_RANGE
tGATT_STATUS
#define GATT_RSP_ERROR
#define GATT_REQ_MTU
#define GATT_RSP_MTU
#define GATT_REQ_FIND_INFO
#define GATT_RSP_FIND_INFO
#define GATT_REQ_FIND_TYPE_VALUE
#define GATT_RSP_FIND_TYPE_VALUE
#define GATT_REQ_READ_BY_TYPE
#define GATT_RSP_READ_BY_TYPE
#define GATT_REQ_READ
#define GATT_RSP_READ
#define GATT_REQ_READ_BLOB
#define GATT_RSP_READ_BLOB
#define GATT_REQ_READ_MULTI
#define GATT_RSP_READ_MULTI
#define GATT_REQ_READ_BY_GRP_TYPE
#define GATT_RSP_READ_BY_GRP_TYPE
#define GATT_REQ_WRITE
#define GATT_RSP_WRITE
#define GATT_CMD_WRITE
#define GATT_REQ_PREPARE_WRITE
#define GATT_RSP_PREPARE_WRITE
#define GATT_REQ_EXEC_WRITE
#define GATT_RSP_EXEC_WRITE
#define GATT_HANDLE_VALUE_NOTIF
#define GATT_HANDLE_VALUE_IND
#define GATT_HANDLE_VALUE_CONF
#define GATT_REQ_READ_MULTI_VAR
#define GATT_RSP_READ_MULTI_VAR
#define GATT_HANDLE_MULTI_VALUE_NOTIF
#define GATT_SIGN_CMD_WRITE
#define GATT_OP_CODE_MAX
#define GATT_COMMAND_FLAG
#define GATT_HANDLE_IS_VALID
#define GATT_CONN_UNKNOWN
#define GATT_CONN_L2C_FAILURE
#define GATT_CONN_TIMEOUT
#define GATT_CONN_TERMINATE_PEER_USER
#define GATT_CONN_TERMINATE_LOCAL_HOST
#define GATT_CONN_FAIL_ESTABLISH
#define GATT_CONN_LMP_TIMEOUT
#define GATT_CONN_CANCEL
tGATT_DISCONN_REASON
#define GATT_MAX_MTU_SIZE
#define GATT_MAX_ATTR_LEN
#define GATT_DEF_BLE_MTU_SIZE
#define GATT_INVALID_CONN_ID
#define GATT_CL_MAX_LCB
#define GATT_MAX_SCCB
#define GATTC_NOTIF_TIMEOUT
#define GATT_PERM_READ
#define GATT_PERM_READ_ENCRYPTED
#define GATT_PERM_READ_ENC_MITM
#define GATT_PERM_WRITE
#define GATT_PERM_WRITE_ENCRYPTED
#define GATT_PERM_WRITE_ENC_MITM
#define GATT_PERM_WRITE_SIGNED
#define GATT_PERM_WRITE_SIGNED_MITM
#define GATT_PERM_READ_AUTHORIZATION
#define GATT_PERM_WRITE_AUTHORIZATION
tGATT_PERM
#define GATT_ENCRYPT_KEY_SIZE_MASK
#define GATT_READ_ALLOWED
#define GATT_READ_AUTH_REQUIRED
#define GATT_READ_MITM_REQUIRED
#define GATT_READ_ENCRYPTED_REQUIRED
#define GATT_READ_AUTHORIZATION
#define GATT_WRITE_AUTH_REQUIRED
#define GATT_WRITE_MITM_REQUIRED
#define GATT_WRITE_ENCRYPTED_PERM
#define GATT_WRITE_SIGNED_PERM
#define GATT_WRITE_AUTHORIZATION
#define GATT_CHAR_PROP_BIT_BROADCAST
#define GATT_CHAR_PROP_BIT_READ
#define GATT_CHAR_PROP_BIT_WRITE_NR
#define GATT_CHAR_PROP_BIT_WRITE
#define GATT_CHAR_PROP_BIT_NOTIFY
#define GATT_CHAR_PROP_BIT_INDICATE
#define GATT_CHAR_PROP_BIT_AUTH
#define GATT_CHAR_PROP_BIT_EXT_PROP
tGATT_CHAR_PROP
<anonymous enum>
tGATT_FORMAT
tGATT_CHAR_PRES
tGATT_CHAR_RPT_REF
#define GATT_VALID_RANGE_MAX_SIZE
tGATT_VALID_RANGE
#define GATT_AGGR_HANDLE_NUM_MAX
tGATT_CHAR_AGGRE
#define GATT_CHAR_BIT_REL_WRITE
#define GATT_CHAR_BIT_WRITE_AUX
#define GATT_CLT_CONFIG_NONE
#define GATT_CLT_CONFIG_NOTIFICATION
#define GATT_CLT_CONFIG_INDICATION
tGATT_CLT_CHAR_CONFIG
#define GATT_SVR_CONFIG_NONE
#define GATT_SVR_CONFIG_BROADCAST
tGATT_SVR_CHAR_CONFIG
#define GATT_CHAR_BIT_REL_WRITE
#define GATT_CHAR_BIT_WRITE_AUX
#define GATT_AUTH_REQ_NONE
#define GATT_AUTH_REQ_NO_MITM
#define GATT_AUTH_REQ_MITM
#define GATT_AUTH_REQ_SIGNED_NO_MITM
#define GATT_AUTH_REQ_SIGNED_MITM
tGATT_AUTH_REQ
tGATT_VALUE
tGATT_ATTR_VAL
tGATTS_ATTR_CONTROL
#define GATT_ATTR_VALUE_ALLOCATED
tGATT_ATTR_MASK
tGATTS_RSP
#define GATT_TRANSPORT_LE
#define GATT_TRANSPORT_BR_EDR
#define GATT_TRANSPORT_LE_BR_EDR
tGATT_TRANSPORT
#define GATT_PREP_WRITE_CANCEL
#define GATT_PREP_WRITE_EXEC
tGATT_EXEC_FLAG
tGATT_READ_REQ
tGATT_WRITE_REQ
tGATTS_DATA
tGATT_SERV_IF
<anonymous enum>
tGATTS_REQ_TYPE
<anonymous enum>
tGATT_DISC_TYPE
tGATT_DISC_PARAM
<anonymous enum>
tGATT_READ_TYPE
tGATT_READ_BY_TYPE
#define GATT_MAX_READ_MULTI_HANDLES
tGATT_READ_MULTI
tGATT_READ_BY_HANDLE
tGATT_READ_PARTIAL
tGATT_READ_PARAM
<anonymous enum>
tGATT_WRITE_TYPE
tGATT_CL_COMPLETE
#define GATTC_OPTYPE_NONE
#define GATTC_OPTYPE_DISCOVERY
#define GATTC_OPTYPE_READ
#define GATTC_OPTYPE_WRITE
#define GATTC_OPTYPE_EXE_WRITE
#define GATTC_OPTYPE_CONFIG
#define GATTC_OPTYPE_NOTIFICATION
#define GATTC_OPTYPE_INDICATION
tGATTC_OPTYPE
tGATT_CHAR_DCLR_VAL
tGATT_GROUP_VALUE
tGATT_INCL_SRVC
tGATT_DISC_VALUE
tGATT_DISC_RES
#define GATT_LINK_NO_IDLE_TIMEOUT
#define GATT_INVALID_ACL_HANDLE
tGATT_DISC_RES_CB
tGATT_DISC_CMPL_CB
tGATT_CMPL_CBACK
tGATT_CONN_CBACK
tGATT_REQ_CBACK
tGATT_CONGESTION_CBACK
tGATT_ENC_CMPL_CB
tGATT_CBACK
tGATTS_HNDL_RANGE
#define GATTS_SRV_CHG_CMD_ADD_CLIENT
#define GATTS_SRV_CHG_CMD_UPDATE_CLIENT
#define GATTS_SRV_CHG_CMD_REMOVE_CLIENT
#define GATTS_SRV_CHG_CMD_READ_NUM_CLENTS
#define GATTS_SRV_CHG_CMD_READ_CLENT
tGATTS_SRV_CHG_CMD
tGATTS_SRV_CHG
tGATTS_SRV_CHG_REQ
tGATTS_SRV_CHG_RSP
tGATTS_PENDING_NEW_SRV_START
tGATTS_NV_SAVE_CBACK
tGATTS_NV_SRV_CHG_CBACK
tGATT_APPL_INFO
tGATT_HLV
GATT_SetTraceLevel(UINT8);
...
GATTS_AddHandleRange(tGATTS_HNDL_RANGE *);
GATTS_NVRegister(const tGATT_APPL_INFO *);
GATTS_CreateService(tGATT_IF, tBT_UUID *, UINT16, UINT16, BOOLEAN);
GATTS_AddIncludeService(UINT16, UINT16);
GATTS_AddCharacteristic(UINT16, tBT_UUID *, tGATT_PERM, tGATT_CHAR_PROP, tGATT_ATTR_VAL *, tGATTS_ATTR_CONTROL *);
GATTS_AddCharDescriptor(UINT16, tGATT_PERM, tBT_UUID *, tGATT_ATTR_VAL *, tGATTS_ATTR_CONTROL *);
GATTS_DeleteService(tGATT_IF, tBT_UUID *, UINT16);
GATTS_StartService(tGATT_IF, UINT16, tGATT_TRANSPORT);
GATTS_StopService(UINT16);
GATTS_HandleValueIndication(UINT16, UINT16, UINT16, UINT8 *);
GATTS_HandleValueNotification(UINT16, UINT16, UINT16, UINT8 *);
GATTS_SendRsp(UINT16, UINT32, tGATT_STATUS, tGATTS_RSP *);
GATTS_SetAttributeValue(UINT16, UINT16, UINT8 *);
GATTS_GetAttributeValue(UINT16, UINT16 *, UINT8 **);
GATTS_GetAttributeValueInternal(UINT16, UINT16 *, UINT8 **);
GATTC_ConfigureMTU(UINT16);
GATTC_Discover(UINT16, tGATT_DISC_TYPE, tGATT_DISC_PARAM *);
GATTC_Read(UINT16, tGATT_READ_TYPE, tGATT_READ_PARAM *);
GATTC_Write(UINT16, tGATT_WRITE_TYPE, tGATT_VALUE *);
GATTC_ExecuteWrite(UINT16, BOOLEAN);
GATTC_SendHandleValueConfirm(UINT16, UINT16);
GATTC_AutoDiscoverEnable(UINT8);
GATT_SetIdleTimeout(UINT8 *, UINT16, tGATT_TRANSPORT);
GATT_Register(tBT_UUID *, const tGATT_CBACK *);
GATT_Deregister(tGATT_IF);
GATT_StartIf(tGATT_IF);
GATT_Connect(tGATT_IF, UINT8 *, tBLE_ADDR_TYPE, BOOLEAN, tBT_TRANSPORT, BOOLEAN);
GATT_CancelConnect(tGATT_IF, UINT8 *, BOOLEAN);
GATT_Disconnect(UINT16);
GATT_SendServiceChangeIndication(UINT8 *);
GATT_GetConnectionInfor(UINT16, tGATT_IF *, UINT8 *, tBT_TRANSPORT *);
GATT_GetConnIdIfConnected(tGATT_IF, UINT8 *, UINT16 *, tBT_TRANSPORT);
GATT_Listen(tGATT_IF, BOOLEAN, BD_ADDR_PTR);
GATT_ConfigServiceChangeCCC(UINT8 *, BOOLEAN, tBT_TRANSPORT);
GATTS_SetServiceChangeMode(UINT8);
GATTS_HandleMultiValueNotification(UINT16, tGATT_HLV *, UINT16);
GATTS_ShowLocalDatabase();
Files
loading...
SourceVuESP-IDF Framework and ExamplesESP-IDFcomponents/bt/host/bluedroid/stack/include/stack/gatt_api.h
 
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
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
908
909
910
911
912
913
914
915
916
917
918
919
920
921
922
923
924
925
926
927
928
929
930
931
932
933
934
935
936
937
938
939
940
941
942
943
944
945
946
947
948
949
950
951
952
953
954
955
956
957
958
959
960
961
962
963
964
965
966
967
968
969
970
971
972
973
974
975
976
977
978
979
980
981
982
983
984
985
986
987
988
989
990
991
992
993
994
995
996
997
998
999
1000
1001
1002
1003
1004
1005
1006
1007
1008
1009
1010
1011
1012
1013
1014
1015
1016
1017
1018
1019
1020
1021
1022
1023
1024
1025
1026
1027
1028
1029
1030
1031
1032
1033
1034
1035
1036
1037
1038
1039
1040
1041
1042
1043
1044
1045
1046
1047
1048
1049
1050
1051
1052
1053
1054
1055
1056
1057
1058
1059
1060
1061
1062
1063
1064
1065
1066
1067
1068
1069
1070
1071
1072
1073
1074
1075
1076
1077
1078
1079
1080
1081
1082
1083
1084
1085
1086
1087
1088
1089
1090
1091
1092
1093
1094
1095
1096
1097
1098
1099
1100
1101
1102
1103
1104
1105
1106
1107
1108
1109
1110
1111
1112
1113
1114
1115
1116
1117
1118
1119
1120
1121
1122
1123
1124
1125
1126
1127
1128
1129
1130
1131
1132
1133
1134
1135
1136
1137
1138
1139
1140
1141
1142
1143
1144
1145
1146
1147
1148
1149
1150
1151
1152
1153
1154
1155
1156
1157
1158
1159
1160
1161
1162
1163
1164
1165
1166
1167
1168
1169
1170
1171
1172
1173
1174
1175
1176
1177
1178
1179
1180
1181
1182
1183
1184
1185
1186
1187
1188
1189
1190
1191
1192
1193
1194
1195
1196
1197
1198
1199
1200
1201
1202
1203
1204
1205
1206
1207
1208
1209
1210
1211
1212
1213
1214
1215
1216
1217
1218
1219
1220
1221
1222
1223
1224
1225
1226
1227
1228
1229
1230
1231
1232
1233
1234
1235
1236
1237
1238
1239
1240
1241
1242
1243
1244
1245
1246
1247
1248
1249
1250
1251
1252
1253
1254
1255
1256
1257
1258
1259
1260
1261
1262
1263
1264
1265
1266
1267
1268
1269
1270
1271
1272
1273
1274
1275
1276
1277
1278
1279
1280
1281
1282
1283
1284
1285
1286
1287
1288
1289
1290
1291
1292
1293
1294
1295
1296
1297
1298
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
/****************************************************************************** * * Copyright (C) 1999-2012 Broadcom Corporation * * 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 GATT_API_H #define GATT_API_H #include "common/bt_target.h" #include "stack/gattdefs.h" #include "stack/btm_ble_api.h" /***************************************************************************** ** Constants *****************************************************************************//* ... */ /* Success code and error codes */ #define GATT_SUCCESS 0x00 #define GATT_INVALID_HANDLE 0x01 #define GATT_READ_NOT_PERMIT 0x02 #define GATT_WRITE_NOT_PERMIT 0x03 #define GATT_INVALID_PDU 0x04 #define GATT_INSUF_AUTHENTICATION 0x05 #define GATT_REQ_NOT_SUPPORTED 0x06 #define GATT_INVALID_OFFSET 0x07 #define GATT_INSUF_AUTHORIZATION 0x08 #define GATT_PREPARE_Q_FULL 0x09 #define GATT_NOT_FOUND 0x0a #define GATT_NOT_LONG 0x0b #define GATT_INSUF_KEY_SIZE 0x0c #define GATT_INVALID_ATTR_LEN 0x0d #define GATT_ERR_UNLIKELY 0x0e #define GATT_INSUF_ENCRYPTION 0x0f #define GATT_UNSUPPORT_GRP_TYPE 0x10 #define GATT_INSUF_RESOURCE 0x11 #define GATT_DATABASE_OUT_OF_SYNC 0x12 #define GATT_VALUE_NOT_ALLOWED 0x13 #define GATT_NO_RESOURCES 0x80 #define GATT_INTERNAL_ERROR 0x81 #define GATT_WRONG_STATE 0x82 #define GATT_DB_FULL 0x83 #define GATT_BUSY 0x84 #define GATT_ERROR 0x85 #define GATT_CMD_STARTED 0x86 #define GATT_ILLEGAL_PARAMETER 0x87 #define GATT_PENDING 0x88 #define GATT_AUTH_FAIL 0x89 #define GATT_MORE 0x8a #define GATT_INVALID_CFG 0x8b #define GATT_SERVICE_STARTED 0x8c #define GATT_ENCRYPED_MITM GATT_SUCCESS #define GATT_ENCRYPED_NO_MITM 0x8d #define GATT_NOT_ENCRYPTED 0x8e #define GATT_CONGESTED 0x8f #define GATT_DUP_REG 0x90 #define GATT_ALREADY_OPEN 0x91 #define GATT_CANCEL 0x92 /* 0xE0 ~ 0xFC reserved for future use */ #define GATT_STACK_RSP 0xE0 #define GATT_APP_RSP 0xE1 //Error caused by customer application or stack bug #define GATT_UNKNOWN_ERROR 0XEF #define GATT_CCC_CFG_ERR 0xFD /* Client Characteristic Configuration Descriptor Improperly Configured */ #define GATT_PRC_IN_PROGRESS 0xFE /* Procedure Already in progress */ #define GATT_OUT_OF_RANGE 0xFF /* Attribute value out of range */46 defines typedef UINT8 tGATT_STATUS; #define GATT_RSP_ERROR 0x01 #define GATT_REQ_MTU 0x02 #define GATT_RSP_MTU 0x03 #define GATT_REQ_FIND_INFO 0x04 #define GATT_RSP_FIND_INFO 0x05 #define GATT_REQ_FIND_TYPE_VALUE 0x06 #define GATT_RSP_FIND_TYPE_VALUE 0x07 #define GATT_REQ_READ_BY_TYPE 0x08 #define GATT_RSP_READ_BY_TYPE 0x09 #define GATT_REQ_READ 0x0A #define GATT_RSP_READ 0x0B #define GATT_REQ_READ_BLOB 0x0C #define GATT_RSP_READ_BLOB 0x0D #define GATT_REQ_READ_MULTI 0x0E #define GATT_RSP_READ_MULTI 0x0F #define GATT_REQ_READ_BY_GRP_TYPE 0x10 #define GATT_RSP_READ_BY_GRP_TYPE 0x11 #define GATT_REQ_WRITE 0x12 /* 0001-0010 (write)*/ #define GATT_RSP_WRITE 0x13 #define GATT_CMD_WRITE 0x52 /* changed in V4.0 01001-0010(write cmd)*/ #define GATT_REQ_PREPARE_WRITE 0x16 #define GATT_RSP_PREPARE_WRITE 0x17 #define GATT_REQ_EXEC_WRITE 0x18 #define GATT_RSP_EXEC_WRITE 0x19 #define GATT_HANDLE_VALUE_NOTIF 0x1B #define GATT_HANDLE_VALUE_IND 0x1D #define GATT_HANDLE_VALUE_CONF 0x1E #define GATT_REQ_READ_MULTI_VAR 0x20 #define GATT_RSP_READ_MULTI_VAR 0x21 #define GATT_HANDLE_MULTI_VALUE_NOTIF 0x23 #define GATT_SIGN_CMD_WRITE 0xD2 /* changed in V4.0 1101-0010 (signed write) see write cmd above*/ #define GATT_OP_CODE_MAX GATT_HANDLE_MULTI_VALUE_NOTIF + 1 /* 0x1E = 30 + 1 = 31*/ #define GATT_COMMAND_FLAG 0x40 /* Command Flag: set to one means command */ #define GATT_HANDLE_IS_VALID(x) ((x) != 0) #define GATT_CONN_UNKNOWN 0 #define GATT_CONN_L2C_FAILURE 1 /* general L2cap failure */ #define GATT_CONN_TIMEOUT HCI_ERR_CONNECTION_TOUT /* 0x08 connection timeout */ #define GATT_CONN_TERMINATE_PEER_USER HCI_ERR_PEER_USER /* 0x13 connection terminate by peer user */ #define GATT_CONN_TERMINATE_LOCAL_HOST HCI_ERR_CONN_CAUSE_LOCAL_HOST /* 0x16 connectionterminated by local host */ #define GATT_CONN_FAIL_ESTABLISH HCI_ERR_CONN_FAILED_ESTABLISHMENT/* 0x03E connection fail to establish */ #define GATT_CONN_LMP_TIMEOUT HCI_ERR_LMP_RESPONSE_TIMEOUT /* 0x22 connection fail for LMP response tout */ #define GATT_CONN_CANCEL L2CAP_CONN_CANCEL /* 0x0100 L2CAP connection cancelled */42 defines typedef UINT16 tGATT_DISCONN_REASON; /* MAX GATT MTU size *//* ... */ #ifndef GATT_MAX_MTU_SIZE #define GATT_MAX_MTU_SIZE 517 #endif /* max length of an attribute value *//* ... */ #ifndef GATT_MAX_ATTR_LEN #define GATT_MAX_ATTR_LEN 512 #endif /* default GATT MTU size over LE link *//* ... */ #define GATT_DEF_BLE_MTU_SIZE 23 /* invalid connection ID *//* ... */ #define GATT_INVALID_CONN_ID 0xFFFF #ifndef GATT_CL_MAX_LCB #define GATT_CL_MAX_LCB 12 // 22 #endif #ifndef GATT_MAX_SCCB #define GATT_MAX_SCCB 10 #endif /* GATT notification caching timer, default to be three seconds *//* ... */ #ifndef GATTC_NOTIF_TIMEOUT #define GATTC_NOTIF_TIMEOUT 3 #endif /***************************************************************************** ** GATT Structure Definition *****************************************************************************//* ... */ /* Attribute permissions *//* ... */ #define GATT_PERM_READ (1 << 0) /* bit 0 */ #define GATT_PERM_READ_ENCRYPTED (1 << 1) /* bit 1 */ #define GATT_PERM_READ_ENC_MITM (1 << 2) /* bit 2 */ #define GATT_PERM_WRITE (1 << 4) /* bit 4 */ #define GATT_PERM_WRITE_ENCRYPTED (1 << 5) /* bit 5 */ #define GATT_PERM_WRITE_ENC_MITM (1 << 6) /* bit 6 */ #define GATT_PERM_WRITE_SIGNED (1 << 7) /* bit 7 */ #define GATT_PERM_WRITE_SIGNED_MITM (1 << 8) /* bit 8 */ #define GATT_PERM_READ_AUTHORIZATION (1 << 9) /* bit 9 */ #define GATT_PERM_WRITE_AUTHORIZATION (1 << 10)/* bit 10 */10 defines typedef UINT16 tGATT_PERM; #define GATT_ENCRYPT_KEY_SIZE_MASK (0xF000) /* the MS nibble of tGATT_PERM; key size 7=0; size 16=9 */ #define GATT_READ_ALLOWED (GATT_PERM_READ | GATT_PERM_READ_ENCRYPTED | GATT_PERM_READ_ENC_MITM | GATT_PERM_READ_AUTHORIZATION) #define GATT_READ_AUTH_REQUIRED (GATT_PERM_READ_ENCRYPTED) #define GATT_READ_MITM_REQUIRED (GATT_PERM_READ_ENC_MITM) #define GATT_READ_ENCRYPTED_REQUIRED (GATT_PERM_READ_ENCRYPTED | GATT_PERM_READ_ENC_MITM) #define GATT_READ_AUTHORIZATION (GATT_PERM_READ_AUTHORIZATION) #define GATT_WRITE_ALLOWED (GATT_PERM_WRITE | GATT_PERM_WRITE_ENCRYPTED | GATT_PERM_WRITE_ENC_MITM | \ GATT_PERM_WRITE_SIGNED | GATT_PERM_WRITE_SIGNED_MITM | GATT_PERM_WRITE_AUTHORIZATION)... #define GATT_WRITE_AUTH_REQUIRED (GATT_PERM_WRITE_ENCRYPTED | GATT_PERM_WRITE_SIGNED) #define GATT_WRITE_MITM_REQUIRED (GATT_PERM_WRITE_ENC_MITM | GATT_PERM_WRITE_SIGNED_MITM) #define GATT_WRITE_ENCRYPTED_PERM (GATT_PERM_WRITE_ENCRYPTED | GATT_PERM_WRITE_ENC_MITM) #define GATT_WRITE_SIGNED_PERM (GATT_PERM_WRITE_SIGNED | GATT_PERM_WRITE_SIGNED_MITM) #define GATT_WRITE_AUTHORIZATION (GATT_PERM_WRITE_AUTHORIZATION) /* Characteristic properties *//* ... */ #define GATT_CHAR_PROP_BIT_BROADCAST (1 << 0) #define GATT_CHAR_PROP_BIT_READ (1 << 1) #define GATT_CHAR_PROP_BIT_WRITE_NR (1 << 2) #define GATT_CHAR_PROP_BIT_WRITE (1 << 3) #define GATT_CHAR_PROP_BIT_NOTIFY (1 << 4) #define GATT_CHAR_PROP_BIT_INDICATE (1 << 5) #define GATT_CHAR_PROP_BIT_AUTH (1 << 6) #define GATT_CHAR_PROP_BIT_EXT_PROP (1 << 7)20 defines typedef UINT8 tGATT_CHAR_PROP; /* Format of the value of a characteristic. enumeration type *//* ... */ enum { GATT_FORMAT_RES, /* rfu */ GATT_FORMAT_BOOL, /* 0x01 boolean */ GATT_FORMAT_2BITS, /* 0x02 2 bit */ GATT_FORMAT_NIBBLE, /* 0x03 nibble */ GATT_FORMAT_UINT8, /* 0x04 uint8 */ GATT_FORMAT_UINT12, /* 0x05 uint12 */ GATT_FORMAT_UINT16, /* 0x06 uint16 */ GATT_FORMAT_UINT24, /* 0x07 uint24 */ GATT_FORMAT_UINT32, /* 0x08 uint32 */ GATT_FORMAT_UINT48, /* 0x09 uint48 */ GATT_FORMAT_UINT64, /* 0x0a uint64 */ GATT_FORMAT_UINT128, /* 0x0B uint128 */ GATT_FORMAT_SINT8, /* 0x0C signed 8 bit integer */ GATT_FORMAT_SINT12, /* 0x0D signed 12 bit integer */ GATT_FORMAT_SINT16, /* 0x0E signed 16 bit integer */ GATT_FORMAT_SINT24, /* 0x0F signed 24 bit integer */ GATT_FORMAT_SINT32, /* 0x10 signed 32 bit integer */ GATT_FORMAT_SINT48, /* 0x11 signed 48 bit integer */ GATT_FORMAT_SINT64, /* 0x12 signed 64 bit integer */ GATT_FORMAT_SINT128, /* 0x13 signed 128 bit integer */ GATT_FORMAT_FLOAT32, /* 0x14 float 32 */ GATT_FORMAT_FLOAT64, /* 0x15 float 64*/ GATT_FORMAT_SFLOAT, /* 0x16 IEEE-11073 16 bit SFLOAT */ GATT_FORMAT_FLOAT, /* 0x17 IEEE-11073 32 bit SFLOAT */ GATT_FORMAT_DUINT16, /* 0x18 IEEE-20601 format */ GATT_FORMAT_UTF8S, /* 0x19 UTF-8 string */ GATT_FORMAT_UTF16S, /* 0x1a UTF-16 string */ GATT_FORMAT_STRUCT, /* 0x1b Opaque structure*/ GATT_FORMAT_MAX /* 0x1c or above reserved */ }{ ... }; typedef UINT8 tGATT_FORMAT; /* Characteristic Presentation Format Descriptor value *//* ... */ typedef struct { UINT16 unit; /* as UUID defined by SIG */ UINT16 descr; /* as UUID as defined by SIG */ tGATT_FORMAT format; INT8 exp; UINT8 name_spc; /* The name space of the description */ }{ ... } tGATT_CHAR_PRES; /* Characteristic Report reference Descriptor format *//* ... */ typedef struct { UINT8 rpt_id; /* report ID */ UINT8 rpt_type; /* report type */ }{ ... } tGATT_CHAR_RPT_REF; #define GATT_VALID_RANGE_MAX_SIZE 16 typedef struct { UINT8 format; UINT16 len; UINT8 lower_range[GATT_VALID_RANGE_MAX_SIZE]; /* in little endian format */ UINT8 upper_range[GATT_VALID_RANGE_MAX_SIZE]; }{ ... } tGATT_VALID_RANGE; /* Characteristic Aggregate Format attribute value *//* ... */ #define GATT_AGGR_HANDLE_NUM_MAX 10 typedef struct { UINT8 num_handle; UINT16 handle_list[GATT_AGGR_HANDLE_NUM_MAX]; }{ ... } tGATT_CHAR_AGGRE; /* Characteristic descriptor: Extended Properties value *//* ... */ #define GATT_CHAR_BIT_REL_WRITE 0x0001 /* permits reliable writes of the Characteristic Value */ #define GATT_CHAR_BIT_WRITE_AUX 0x0002 /* permits writes to the characteristic descriptor */ /* characteristic descriptor: client configuration value *//* ... */ #define GATT_CLT_CONFIG_NONE 0x0000 #define GATT_CLT_CONFIG_NOTIFICATION 0x0001 #define GATT_CLT_CONFIG_INDICATION 0x00025 defines typedef UINT16 tGATT_CLT_CHAR_CONFIG; /* characteristic descriptor: server configuration value *//* ... */ #define GATT_SVR_CONFIG_NONE 0x0000 #define GATT_SVR_CONFIG_BROADCAST 0x0001 typedef UINT16 tGATT_SVR_CHAR_CONFIG; /* Characteristic descriptor: Extended Properties value *//* ... */ #define GATT_CHAR_BIT_REL_WRITE 0x0001 /* permits reliable writes of the Characteristic Value */ #define GATT_CHAR_BIT_WRITE_AUX 0x0002 /* permits writes to the characteristic descriptor */ /* authentication requirement *//* ... */ #define GATT_AUTH_REQ_NONE 0 #define GATT_AUTH_REQ_NO_MITM 1 /* unauthenticated encryption */ #define GATT_AUTH_REQ_MITM 2 /* authenticated encryption */ #define GATT_AUTH_REQ_SIGNED_NO_MITM 3 #define GATT_AUTH_REQ_SIGNED_MITM 47 defines typedef UINT8 tGATT_AUTH_REQ; /* Attribute Value structure *//* ... */ typedef struct { UINT16 conn_id; UINT16 handle; /* attribute handle */ UINT16 offset; /* attribute value offset, if no offset is needed for the command, ignore it */ UINT16 len; /* length of attribute value */ tGATT_AUTH_REQ auth_req; /* authentication request */ UINT8 value[GATT_MAX_ATTR_LEN]; /* the actual attribute value */ }{ ... } tGATT_VALUE; typedef struct{ UINT16 attr_max_len; UINT16 attr_len; UINT8 *attr_val; }{ ... }tGATT_ATTR_VAL; typedef struct{ uint8_t auto_rsp; }{ ... }tGATTS_ATTR_CONTROL; /* Mask for gatt server attribute */ #define GATT_ATTR_VALUE_ALLOCATED 0x01 typedef UINT8 tGATT_ATTR_MASK; /* Union of the event data which is used in the server respond API to carry the server response information *//* ... */ typedef union { /* data type member event */ tGATT_VALUE attr_value; /* READ, HANDLE_VALUE_IND, PREPARE_WRITE */ /* READ_BLOB, READ_BY_TYPE */ UINT16 handle; /* WRITE, WRITE_BLOB */ }{ ... } tGATTS_RSP; /* Transports for the primary service */ #define GATT_TRANSPORT_LE BT_TRANSPORT_LE #define GATT_TRANSPORT_BR_EDR BT_TRANSPORT_BR_EDR #define GATT_TRANSPORT_LE_BR_EDR (BT_TRANSPORT_LE|BT_TRANSPORT_BR_EDR) typedef UINT8 tGATT_TRANSPORT; #define GATT_PREP_WRITE_CANCEL 0x00 #define GATT_PREP_WRITE_EXEC 0x01 typedef UINT8 tGATT_EXEC_FLAG; /* read request always based on UUID */ typedef struct { UINT16 handle; UINT16 offset; BOOLEAN is_long; BOOLEAN need_rsp; }{ ... } tGATT_READ_REQ; /* write request data */ typedef struct { UINT16 handle; /* attribute handle */ UINT16 offset; /* attribute value offset, if no offset is needed for the command, ignore it */ UINT16 len; /* length of attribute value */ UINT8 value[GATT_MAX_ATTR_LEN]; /* the actual attribute value */ BOOLEAN need_rsp; /* need write response */ BOOLEAN is_prep; /* is prepare write */ }{ ... } tGATT_WRITE_REQ; /* callback data for server access request from client */ typedef union { tGATT_READ_REQ read_req; /* read request, read by Type, read blob */ tGATT_WRITE_REQ write_req; /* write */ /* prepare write */ /* write blob */ UINT16 handle; /* handle value confirmation */ UINT16 mtu; /* MTU exchange request */ tGATT_EXEC_FLAG exec_write; /* execute write */ }{ ... } tGATTS_DATA; typedef UINT8 tGATT_SERV_IF; /* GATT Service Interface */ enum { GATTS_REQ_TYPE_READ = 1, /* Attribute read request */ GATTS_REQ_TYPE_WRITE, /* Attribute write request */ GATTS_REQ_TYPE_WRITE_EXEC, /* Execute write */ GATTS_REQ_TYPE_MTU, /* MTU exchange information */ GATTS_REQ_TYPE_CONF /* handle value confirmation */ }{ ... }; typedef UINT8 tGATTS_REQ_TYPE; /* Client Used Data Structure *//* ... */ /* definition of different discovery types */ enum { GATT_DISC_SRVC_ALL = 1, /* discover all services */ GATT_DISC_SRVC_BY_UUID, /* discover service of a special type */ GATT_DISC_INC_SRVC, /* discover the included service within a service */ GATT_DISC_CHAR, /* discover characteristics of a service with/without type requirement */ GATT_DISC_CHAR_BY_UUID, /* discover characteristic with type requirement */ GATT_DISC_CHAR_DSCPT, /* discover characteristic descriptors of a character */ GATT_DISC_MAX /* maximnun discover type */ }{ ... }; typedef UINT8 tGATT_DISC_TYPE; /* Discover parameters of different discovery types *//* ... */ typedef struct { tBT_UUID service; UINT16 s_handle; UINT16 e_handle; }{ ... } tGATT_DISC_PARAM; /* GATT read type enumeration *//* ... */ enum { GATT_READ_BY_TYPE = 1, GATT_READ_BY_HANDLE, GATT_READ_MULTIPLE, GATT_READ_MULTIPLE_VAR, GATT_READ_CHAR_VALUE, GATT_READ_PARTIAL, GATT_READ_MAX }{ ... }; typedef UINT8 tGATT_READ_TYPE; /* Read By Type Request (GATT_READ_BY_TYPE) Data *//* ... */ typedef struct { tGATT_AUTH_REQ auth_req; UINT16 s_handle; UINT16 e_handle; tBT_UUID uuid; }{ ... } tGATT_READ_BY_TYPE; /* GATT_READ_MULTIPLE request data *//* ... */ #define GATT_MAX_READ_MULTI_HANDLES 10 /* Max attributes to read in one request */ typedef struct { tGATT_AUTH_REQ auth_req; UINT16 num_handles; /* number of handles to read */ UINT16 handles[GATT_MAX_READ_MULTI_HANDLES]; /* handles list to be read */ }{ ... } tGATT_READ_MULTI; /* Read By Handle Request (GATT_READ_BY_HANDLE) data */ typedef struct { tGATT_AUTH_REQ auth_req; UINT16 handle; }{ ... } tGATT_READ_BY_HANDLE; /* READ_BT_HANDLE_Request data */ typedef struct { tGATT_AUTH_REQ auth_req; UINT16 handle; UINT16 offset; }{ ... } tGATT_READ_PARTIAL; /* Read Request Data *//* ... */ typedef union { tGATT_READ_BY_TYPE service; tGATT_READ_BY_TYPE char_type; /* characteristic type */ tGATT_READ_MULTI read_multiple; tGATT_READ_BY_HANDLE by_handle; tGATT_READ_PARTIAL partial; }{ ... } tGATT_READ_PARAM; /* GATT write type enumeration */ enum { GATT_WRITE_NO_RSP = 1, GATT_WRITE , GATT_WRITE_PREPARE }{ ... }; typedef UINT8 tGATT_WRITE_TYPE; /* Client Operation Complete Callback Data *//* ... */ typedef union { tGATT_VALUE att_value; UINT16 mtu; UINT16 handle; }{ ... } tGATT_CL_COMPLETE; /* GATT client operation type, used in client callback function *//* ... */ #define GATTC_OPTYPE_NONE 0 #define GATTC_OPTYPE_DISCOVERY 1 #define GATTC_OPTYPE_READ 2 #define GATTC_OPTYPE_WRITE 3 #define GATTC_OPTYPE_EXE_WRITE 4 #define GATTC_OPTYPE_CONFIG 5 #define GATTC_OPTYPE_NOTIFICATION 6 #define GATTC_OPTYPE_INDICATION 78 defines typedef UINT8 tGATTC_OPTYPE; /* characteristic declaration *//* ... */ typedef struct { tGATT_CHAR_PROP char_prop; /* characteristic properties */ UINT16 val_handle; /* characteristic value attribute handle */ tBT_UUID char_uuid; /* characteristic UUID type */ }{ ... } tGATT_CHAR_DCLR_VAL; /* primary service group data *//* ... */ typedef struct { UINT16 e_handle; /* ending handle of the group */ tBT_UUID service_type; /* group type */ }{ ... } tGATT_GROUP_VALUE; /* included service attribute value *//* ... */ typedef struct { tBT_UUID service_type; /* included service UUID */ UINT16 s_handle; /* starting handle */ UINT16 e_handle; /* ending handle */ }{ ... } tGATT_INCL_SRVC; typedef union { tGATT_INCL_SRVC incl_service; /* include service value */ tGATT_GROUP_VALUE group_value; /* Service UUID type. This field is used with GATT_DISC_SRVC_ALL or GATT_DISC_SRVC_BY_UUID type of discovery result callback. *//* ... */ UINT16 handle; /* When used with GATT_DISC_INC_SRVC type discovery result, it is the included service starting handle.*//* ... */ tGATT_CHAR_DCLR_VAL dclr_value; /* Characteristic declaration value. This field is used with GATT_DISC_CHAR type discovery.*//* ... */ }{ ... } tGATT_DISC_VALUE; /* discover result record *//* ... */ typedef struct { tBT_UUID type; UINT16 handle; tGATT_DISC_VALUE value; }{ ... } tGATT_DISC_RES; #define GATT_LINK_IDLE_TIMEOUT_WHEN_NO_APP 0 /* start a idle timer for this duration when no application need to use the link *//* ... */ #define GATT_LINK_NO_IDLE_TIMEOUT 0xFFFF #define GATT_INVALID_ACL_HANDLE 0xFFFF /* discover result callback function */ typedef void (tGATT_DISC_RES_CB) (UINT16 conn_id, tGATT_DISC_TYPE disc_type, tGATT_DISC_RES *p_data); /* discover complete callback function */ typedef void (tGATT_DISC_CMPL_CB) (UINT16 conn_id, tGATT_DISC_TYPE disc_type, tGATT_STATUS status); /* Define a callback function for when read/write/disc/config operation is completed. */ typedef void (tGATT_CMPL_CBACK) (UINT16 conn_id, tGATTC_OPTYPE op, tGATT_STATUS status, tGATT_CL_COMPLETE *p_data); /* Define a callback function when an initialized connection is established. */ typedef void (tGATT_CONN_CBACK) (tGATT_IF gatt_if, BD_ADDR bda, UINT16 conn_id, BOOLEAN connected, tGATT_DISCONN_REASON reason, tBT_TRANSPORT transport); /* attribute request callback for ATT server */ typedef void (tGATT_REQ_CBACK )(UINT16 conn_id, UINT32 trans_id, tGATTS_REQ_TYPE type, tGATTS_DATA *p_data); /* channel congestion/uncongestion callback */ typedef void (tGATT_CONGESTION_CBACK )(UINT16 conn_id, BOOLEAN congested); /* Define a callback function when encryption is established. */ typedef void (tGATT_ENC_CMPL_CB)(tGATT_IF gatt_if, BD_ADDR bda); /* Define the structure that applications use to register with ** GATT. This structure includes callback functions. All functions ** MUST be provided. *//* ... */ typedef struct { tGATT_CONN_CBACK *p_conn_cb; tGATT_CMPL_CBACK *p_cmpl_cb; tGATT_DISC_RES_CB *p_disc_res_cb; tGATT_DISC_CMPL_CB *p_disc_cmpl_cb; tGATT_REQ_CBACK *p_req_cb; tGATT_ENC_CMPL_CB *p_enc_cmpl_cb; tGATT_CONGESTION_CBACK *p_congestion_cb; }{ ... } tGATT_CBACK; /*********************** Start Handle Management Definitions ********************** *//* ... */ typedef struct { tBT_UUID app_uuid128; tBT_UUID svc_uuid; UINT16 svc_inst; UINT16 s_handle; UINT16 e_handle; BOOLEAN is_primary; /* primary service or secondary */ }{ ... } tGATTS_HNDL_RANGE; #define GATTS_SRV_CHG_CMD_ADD_CLIENT 1 #define GATTS_SRV_CHG_CMD_UPDATE_CLIENT 2 #define GATTS_SRV_CHG_CMD_REMOVE_CLIENT 3 #define GATTS_SRV_CHG_CMD_READ_NUM_CLENTS 4 #define GATTS_SRV_CHG_CMD_READ_CLENT 55 defines typedef UINT8 tGATTS_SRV_CHG_CMD; typedef struct { BD_ADDR bda; BOOLEAN srv_changed; }{ ... } tGATTS_SRV_CHG; typedef union { tGATTS_SRV_CHG srv_chg; UINT8 client_read_index; /* only used for sequential reading client srv chg info */ }{ ... } tGATTS_SRV_CHG_REQ; typedef union { tGATTS_SRV_CHG srv_chg; UINT8 num_clients; }{ ... } tGATTS_SRV_CHG_RSP; typedef struct { tGATTS_HNDL_RANGE *p_new_srv_start; }{ ... } tGATTS_PENDING_NEW_SRV_START; /* Attribute server handle ranges NV storage callback functions *//* ... */ typedef void (tGATTS_NV_SAVE_CBACK)(BOOLEAN is_saved, tGATTS_HNDL_RANGE *p_hndl_range); typedef BOOLEAN (tGATTS_NV_SRV_CHG_CBACK)(tGATTS_SRV_CHG_CMD cmd, tGATTS_SRV_CHG_REQ *p_req, tGATTS_SRV_CHG_RSP *p_rsp); typedef struct { tGATTS_NV_SAVE_CBACK *p_nv_save_callback; tGATTS_NV_SRV_CHG_CBACK *p_srv_chg_callback; }{ ... } tGATT_APPL_INFO; typedef struct { UINT16 handle; UINT16 length; UINT8 *value; }{ ... } tGATT_HLV; /* *********************** End Handle Management Definitions **********************//* ... */ /***************************************************************************** ** External Function Declarations *****************************************************************************//* ... */ #ifdef __cplusplus extern "C" { #endif /******************************************************************************* ** ** Function GATT_SetTraceLevel ** ** Description This function sets the trace level. If called with ** a value of 0xFF, it simply returns the current trace level. ** ** Returns The new or current trace level ** *******************************************************************************/ extern UINT8 GATT_SetTraceLevel (UINT8 new_level); /*******************************************************************************/ /* GATT Profile API Functions */ /*******************************************************************************/ /* GATT Profile Server Functions */ /*******************************************************************************/ /******************************************************************************* ** ** Function GATTS_AddHandleRange ** ** Description This function add the allocated handles range for the specified ** application UUID, service UUID and service instance ** ** Parameter p_hndl_range: pointer to allocated handles information ** ** Returns TRUE if handle range is added successfully; otherwise FALSE. ** *******************************************************************************/ extern BOOLEAN GATTS_AddHandleRange(tGATTS_HNDL_RANGE *p_hndl_range); /******************************************************************************* ** ** Function GATTS_NVRegister ** ** Description Application manager calls this function to register for ** NV save callback function. There can be one and only one ** NV save callback function. ** ** Parameter p_cb_info : callback information ** ** Returns TRUE if registered OK, else FALSE ** *******************************************************************************/ extern BOOLEAN GATTS_NVRegister (const tGATT_APPL_INFO *p_cb_info); /******************************************************************************* ** ** Function GATTS_CreateService ** ** Description This function is called to reserve a block of handles for a service. ** ** *** It should be called only once per service instance *** ** ** Parameter gatt_if : application if ** p_svc_uuid : service UUID ** svc_inst : instance of the service inside the application ** num_handles : number of handles needed by the service. ** is_pri : is a primary service or not. ** ** Returns service handle if successful, otherwise 0. ** *******************************************************************************/ extern UINT16 GATTS_CreateService (tGATT_IF gatt_if, tBT_UUID *p_svc_uuid, UINT16 svc_inst, UINT16 num_handles, BOOLEAN is_pri); /******************************************************************************* ** ** Function GATTS_AddIncludeService ** ** Description This function is called to add an included service. ** ** Parameter service_handle : To which service this included service is added to. ** include_svc_handle : included service handle. ** ** Returns included service attribute handle. If 0, add included service ** fail. ** *******************************************************************************/ extern UINT16 GATTS_AddIncludeService (UINT16 service_handle, UINT16 include_svc_handle); /******************************************************************************* ** ** Function GATTS_AddCharacteristic ** ** Description This function is called to add a characteristic into a service. ** It will add a characteristic declaration and characteristic ** value declaration into the service database identified by the ** service handle. ** ** Parameter service_handle : To which service this included service is added to. ** char_uuid : Characteristic UUID. ** perm : Characteristic value declaration attribute permission. ** property : Characteristic Properties ** ** Returns Characteristic value declaration attribute handle. 0 if add ** characteristic failed. ** *******************************************************************************/ extern UINT16 GATTS_AddCharacteristic (UINT16 service_handle, tBT_UUID *p_char_uuid, tGATT_PERM perm, tGATT_CHAR_PROP property, tGATT_ATTR_VAL *attr_val, tGATTS_ATTR_CONTROL *control); /******************************************************************************* ** ** Function GATTS_AddCharDescriptor ** ** Description This function is called to add a characteristic descriptor ** into a service database. Add descriptor should follow add char ** to which it belongs, and next add char should be done only ** after all add descriptors for the previous char. ** ** Parameter service_handle : To which service this characteristic descriptor ** is added to. ** perm : Characteristic value declaration attribute ** permission. ** p_descr_uuid : Characteristic descriptor UUID. ** ** Returns Characteristic descriptor attribute handle. 0 if add ** characteristic descriptor failed. ** *******************************************************************************/ extern UINT16 GATTS_AddCharDescriptor (UINT16 service_handle, tGATT_PERM perm, tBT_UUID *p_descr_uuid, tGATT_ATTR_VAL *attr_val, tGATTS_ATTR_CONTROL *control); /******************************************************************************* ** ** Function GATTS_DeleteService ** ** Description This function is called to delete a service. ** ** Parameter gatt_if : application interface ** p_svc_uuid : service UUID ** svc_inst : instance of the service inside the application ** ** Returns TRUE if operation succeed, FALSE if handle block was not found. ** *******************************************************************************/ extern BOOLEAN GATTS_DeleteService (tGATT_IF gatt_if, tBT_UUID *p_svc_uuid, UINT16 svc_inst); /******************************************************************************* ** ** Function GATTS_StartService ** ** Description This function is called to start a service with GATT ** ** Parameter gatt_if : service handle. ** p_cback : application service callback functions. ** sup_transport : supported transport(s) for this primary service ** ** return GATT_SUCCESS if successfully started; otherwise error code. ** *******************************************************************************/ extern tGATT_STATUS GATTS_StartService (tGATT_IF gatt_if, UINT16 service_handle, tGATT_TRANSPORT sup_transport); /******************************************************************************* ** ** Function GATTS_StopService ** ** Description This function is called to stop a service ** ** Parameter service_handle : this is the start handle of a service ** ** Returns None. ** *******************************************************************************/ extern void GATTS_StopService (UINT16 service_handle); /******************************************************************************* ** ** Function GATTs_HandleValueIndication ** ** Description This function sends a handle value indication to a client. ** ** Parameter conn_id: connection identifier. ** attr_handle: Attribute handle of this handle value indication. ** val_len: Length of the indicated attribute value. ** p_val: Pointer to the indicated attribute value data. ** ** Returns GATT_SUCCESS if successfully sent or queued; otherwise error code. ** *******************************************************************************/ extern tGATT_STATUS GATTS_HandleValueIndication (UINT16 conn_id, UINT16 attr_handle, UINT16 val_len, UINT8 *p_val); /******************************************************************************* ** ** Function GATTS_HandleValueNotification ** ** Description This function sends a handle value notification to a client. ** ** Parameter conn_id: connection identifier. ** attr_handle: Attribute handle of this handle value indication. ** val_len: Length of the indicated attribute value. ** p_val: Pointer to the indicated attribute value data. ** ** Returns GATT_SUCCESS if successfully sent; otherwise error code. ** *******************************************************************************/ extern tGATT_STATUS GATTS_HandleValueNotification (UINT16 conn_id, UINT16 attr_handle, UINT16 val_len, UINT8 *p_val); /******************************************************************************* ** ** Function GATTS_SendRsp ** ** Description This function sends the server response to client. ** ** Parameter conn_id: connection identifier. ** trans_id: transaction id ** status: response status ** p_msg: pointer to message parameters structure. ** ** Returns GATT_SUCCESS if successfully sent; otherwise error code. ** *******************************************************************************/ extern tGATT_STATUS GATTS_SendRsp (UINT16 conn_id, UINT32 trans_id, tGATT_STATUS status, tGATTS_RSP *p_msg); /******************************************************************************* ** ** Function GATTS_SetAttributeValue ** ** Description This function sends to set the attribute value . ** ** Parameter attr_handle:the attribute handle ** length: the attribute length ** value: the value to be set to the attribute in the database ** ** Returns GATT_SUCCESS if successfully sent; otherwise error code. ** *******************************************************************************/ tGATT_STATUS GATTS_SetAttributeValue(UINT16 attr_handle, UINT16 length, UINT8 *value); /******************************************************************************* ** ** Function GATTS_GetAttributeValue ** ** Description This function sends to set the attribute value . ** ** Parameter attr_handle: the attribute handle ** length:the attribute value length in the database ** value: the attribute value out put ** ** Returns GATT_SUCCESS if successfully sent; otherwise error code. ** *******************************************************************************/ tGATT_STATUS GATTS_GetAttributeValue(UINT16 attr_handle, UINT16 *length, UINT8 **value); tGATT_STATUS GATTS_GetAttributeValueInternal(UINT16 attr_handle, UINT16 *length, UINT8 **value); /*******************************************************************************/ /* GATT Profile Client Functions */ /*******************************************************************************/ /******************************************************************************* ** ** Function GATTC_ConfigureMTU ** ** Description This function is called to configure the ATT MTU size for ** a connection on an LE transport. ** ** Parameters conn_id: connection identifier. ** mtu - attribute MTU size.. ** ** Returns GATT_SUCCESS if command started successfully. ** *******************************************************************************/ extern tGATT_STATUS GATTC_ConfigureMTU (UINT16 conn_id); /******************************************************************************* ** ** Function GATTC_Discover ** ** Description This function is called to do a discovery procedure on ATT server. ** ** Parameters conn_id: connection identifier. ** disc_type:discovery type. ** p_param: parameters of discovery requirement. ** ** Returns GATT_SUCCESS if command received/sent successfully. ** *******************************************************************************/ extern tGATT_STATUS GATTC_Discover (UINT16 conn_id, tGATT_DISC_TYPE disc_type, tGATT_DISC_PARAM *p_param ); /******************************************************************************* ** ** Function GATTC_Read ** ** Description This function is called to read the value of an attribute from ** the server. ** ** Parameters conn_id: connection identifier. ** type - attribute read type. ** p_read - read operation parameters. ** ** Returns GATT_SUCCESS if command started successfully. ** *******************************************************************************/ extern tGATT_STATUS GATTC_Read (UINT16 conn_id, tGATT_READ_TYPE type, tGATT_READ_PARAM *p_read); /******************************************************************************* ** ** Function GATTC_Write ** ** Description This function is called to read the value of an attribute from ** the server. ** ** Parameters conn_id: connection identifier. ** type - attribute write type. ** p_write - write operation parameters. ** ** Returns GATT_SUCCESS if command started successfully. ** *******************************************************************************/ extern tGATT_STATUS GATTC_Write (UINT16 conn_id, tGATT_WRITE_TYPE type, tGATT_VALUE *p_write); /******************************************************************************* ** ** Function GATTC_ExecuteWrite ** ** Description This function is called to send an Execute write request to ** the server. ** ** Parameters conn_id: connection identifier. ** is_execute - to execute or cancel the prepare write request(s) ** ** Returns GATT_SUCCESS if command started successfully. ** *******************************************************************************/ extern tGATT_STATUS GATTC_ExecuteWrite (UINT16 conn_id, BOOLEAN is_execute); /******************************************************************************* ** ** Function GATTC_SendHandleValueConfirm ** ** Description This function is called to send a handle value confirmation ** as response to a handle value notification from server. ** ** Parameters conn_id: connection identifier. ** handle: the handle of the attribute confirmation. ** ** Returns GATT_SUCCESS if command started successfully. ** *******************************************************************************/ extern tGATT_STATUS GATTC_SendHandleValueConfirm (UINT16 conn_id, UINT16 handle); /******************************************************************************* ** ** Function GATTC_AutoDiscoverEnable ** ** Description This function is called to enable/disable auto discover. ** ** Parameters enable: 0 for disable, otherwise enable. ** ** Returns GATT_SUCCESS if command started successfully. ** *******************************************************************************/ extern tGATT_STATUS GATTC_AutoDiscoverEnable(UINT8 enable); /******************************************************************************* ** ** Function GATT_SetIdleTimeout ** ** Description This function (common to both client and server) sets the idle ** timeout for a tansport connection ** ** Parameter bd_addr: target device bd address. ** idle_tout: timeout value in seconds. ** transport: transport option. ** ** Returns void ** *******************************************************************************/ extern void GATT_SetIdleTimeout (BD_ADDR bd_addr, UINT16 idle_tout, tGATT_TRANSPORT transport); /******************************************************************************* ** ** Function GATT_Register ** ** Description This function is called to register an application ** with GATT ** ** Parameter p_app_uuid128: Application UUID ** p_cb_info: callback functions. ** ** Returns 0 for error, otherwise the index of the client registered with GATT ** *******************************************************************************/ extern tGATT_IF GATT_Register (tBT_UUID *p_app_uuid128, const tGATT_CBACK *p_cb_info); /******************************************************************************* ** ** Function GATT_Deregister ** ** Description This function deregistered the application from GATT. ** ** Parameters gatt_if: application interface. ** ** Returns None. ** *******************************************************************************/ extern void GATT_Deregister (tGATT_IF gatt_if); /******************************************************************************* ** ** Function GATT_StartIf ** ** Description This function is called after registration to start receiving ** callbacks for registered interface. Function may call back ** with connection status and queued notifications ** ** Parameter gatt_if: application interface. ** ** Returns None ** *******************************************************************************/ extern void GATT_StartIf (tGATT_IF gatt_if); /******************************************************************************* ** ** Function GATT_Connect ** ** Description This function initiate a connection to a remote device on GATT ** channel. ** ** Parameters gatt_if: application interface ** bd_addr: peer device address. ** bd_addr_type: peer device address type. ** is_direct: is a direct connection or a background auto connection ** transport : Physical transport for GATT connection (BR/EDR or LE) ** ** Returns TRUE if connection started; FALSE if connection start failure. ** *******************************************************************************/ extern BOOLEAN GATT_Connect (tGATT_IF gatt_if, BD_ADDR bd_addr, tBLE_ADDR_TYPE bd_addr_type, BOOLEAN is_direct, tBT_TRANSPORT transport, BOOLEAN is_aux); /******************************************************************************* ** ** Function GATT_CancelConnect ** ** Description This function terminate the connection initiation to a remote ** device on GATT channel. ** ** Parameters gatt_if: client interface. If 0 used as unconditionally disconnect, ** typically used for direct connection cancellation. ** bd_addr: peer device address. ** is_direct: is a direct connection or a background auto connection ** ** Returns TRUE if connection started; FALSE if connection start failure. ** *******************************************************************************/ extern BOOLEAN GATT_CancelConnect (tGATT_IF gatt_if, BD_ADDR bd_addr, BOOLEAN is_direct); /******************************************************************************* ** ** Function GATT_Disconnect ** ** Description This function disconnect the GATT channel for this registered ** application. ** ** Parameters conn_id: connection identifier. ** ** Returns GATT_SUCCESS if disconnected. ** *******************************************************************************/ extern tGATT_STATUS GATT_Disconnect (UINT16 conn_id); /******************************************************************************* ** ** Function GATT_SendServiceChangeIndication ** ** Description This function is to send a service change indication ** ** Parameters bd_addr: peer device address. ** ** Returns status. ** *******************************************************************************/ extern tGATT_STATUS GATT_SendServiceChangeIndication (BD_ADDR bd_addr); /******************************************************************************* ** ** Function GATT_GetConnectionInfor ** ** Description This function use conn_id to find its associated BD address and application ** interface ** ** Parameters conn_id: connection id (input) ** p_gatt_if: application interface (output) ** bd_addr: peer device address. (output) ** transport : physical transport of the GATT connection (BR/EDR or LE) ** ** Returns TRUE the logical link information is found for conn_id ** *******************************************************************************/ extern BOOLEAN GATT_GetConnectionInfor(UINT16 conn_id, tGATT_IF *p_gatt_if, BD_ADDR bd_addr, tBT_TRANSPORT *p_transport); /******************************************************************************* ** ** Function GATT_GetConnIdIfConnected ** ** Description This function find the conn_id if the logical link for BD address ** and application interface is connected ** ** Parameters gatt_if: application interface (input) ** bd_addr: peer device address. (input) ** p_conn_id: connection id (output) ** transport : physical transport of the GATT connection (BR/EDR or LE) ** ** Returns TRUE the logical link is connected ** *******************************************************************************/ extern BOOLEAN GATT_GetConnIdIfConnected(tGATT_IF gatt_if, BD_ADDR bd_addr, UINT16 *p_conn_id, tBT_TRANSPORT transport); /******************************************************************************* ** ** Function GATT_Listen ** ** Description This function start or stop LE advertisement and listen for ** connection. ** ** Parameters gatt_if: application interface ** p_bd_addr: listen for specific address connection, or NULL for ** listen to all device connection. ** start: is a direct connection or a background auto connection ** ** Returns TRUE if advertisement is started; FALSE if adv start failure. ** *******************************************************************************/ extern BOOLEAN GATT_Listen (tGATT_IF gatt_if, BOOLEAN start, BD_ADDR_PTR bd_addr); /******************************************************************************* ** ** Function GATT_ConfigServiceChangeCCC ** ** Description Configure service change indication on remote device ** ** Returns None. ** *******************************************************************************/ extern void GATT_ConfigServiceChangeCCC (BD_ADDR remote_bda, BOOLEAN enable, tBT_TRANSPORT transport); /******************************************************************************* ** ** Function GATTS_SetServiceChangeMode ** ** Description Configure service change indication mode ** ** Parameters mode: service change mode ** ** Returns Status. ** *******************************************************************************/ extern tGATT_STATUS GATTS_SetServiceChangeMode(UINT8 mode); /******************************************************************************* ** ** Function GATTS_HandleMultiValueNotification ** ** Description This function sends multiple handle value notification to a client. ** ** Parameter conn_id: connection identifier. ** tuples: Pointer to handle-length-value tuple list. ** num_tuples: Number of tuples. ** ** Returns GATT_SUCCESS if successfully sent; otherwise error code. ** *******************************************************************************/ extern tGATT_STATUS GATTS_HandleMultiValueNotification (UINT16 conn_id, tGATT_HLV *tuples, UINT16 num_tuples); /******************************************************************************* ** ** Function GATTS_ShowLocalDatabase ** ** Description This function print local service database. ** ** Returns GATT_SUCCESS if successfully sent; otherwise error code. ** *******************************************************************************/ extern tGATT_STATUS GATTS_ShowLocalDatabase(void); #ifdef __cplusplus } #endif #endif /* GATT_API_H */
Details
Show:
from
Types: Columns:
This file uses the notable symbols shown below. Click anywhere in the file to view more details.