1*042d53a7SEvalZero /*
2*042d53a7SEvalZero * Licensed to the Apache Software Foundation (ASF) under one
3*042d53a7SEvalZero * or more contributor license agreements. See the NOTICE file
4*042d53a7SEvalZero * distributed with this work for additional information
5*042d53a7SEvalZero * regarding copyright ownership. The ASF licenses this file
6*042d53a7SEvalZero * to you under the Apache License, Version 2.0 (the
7*042d53a7SEvalZero * "License"); you may not use this file except in compliance
8*042d53a7SEvalZero * with the License. You may obtain a copy of the License at
9*042d53a7SEvalZero *
10*042d53a7SEvalZero * http://www.apache.org/licenses/LICENSE-2.0
11*042d53a7SEvalZero *
12*042d53a7SEvalZero * Unless required by applicable law or agreed to in writing,
13*042d53a7SEvalZero * software distributed under the License is distributed on an
14*042d53a7SEvalZero * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
15*042d53a7SEvalZero * KIND, either express or implied. See the License for the
16*042d53a7SEvalZero * specific language governing permissions and limitations
17*042d53a7SEvalZero * under the License.
18*042d53a7SEvalZero */
19*042d53a7SEvalZero
20*042d53a7SEvalZero #include "host/ble_uuid.h"
21*042d53a7SEvalZero #include "host/ble_gap.h"
22*042d53a7SEvalZero
23*042d53a7SEvalZero #include "btshell.h"
24*042d53a7SEvalZero
25*042d53a7SEvalZero #include "nimble/npl_shell.h"
26*042d53a7SEvalZero
27*042d53a7SEvalZero /**
28*042d53a7SEvalZero * Utility function to log an array of bytes.
29*042d53a7SEvalZero */
30*042d53a7SEvalZero void
print_bytes(const uint8_t * bytes,int len)31*042d53a7SEvalZero print_bytes(const uint8_t *bytes, int len)
32*042d53a7SEvalZero {
33*042d53a7SEvalZero int i;
34*042d53a7SEvalZero
35*042d53a7SEvalZero for (i = 0; i < len; i++) {
36*042d53a7SEvalZero console_printf("%s0x%02x", i != 0 ? ":" : "", bytes[i]);
37*042d53a7SEvalZero }
38*042d53a7SEvalZero }
39*042d53a7SEvalZero
40*042d53a7SEvalZero void
print_mbuf(const struct os_mbuf * om)41*042d53a7SEvalZero print_mbuf(const struct os_mbuf *om)
42*042d53a7SEvalZero {
43*042d53a7SEvalZero int colon;
44*042d53a7SEvalZero
45*042d53a7SEvalZero colon = 0;
46*042d53a7SEvalZero while (om != NULL) {
47*042d53a7SEvalZero if (colon) {
48*042d53a7SEvalZero console_printf(":");
49*042d53a7SEvalZero } else {
50*042d53a7SEvalZero colon = 1;
51*042d53a7SEvalZero }
52*042d53a7SEvalZero print_bytes(om->om_data, om->om_len);
53*042d53a7SEvalZero om = SLIST_NEXT(om, om_next);
54*042d53a7SEvalZero }
55*042d53a7SEvalZero }
56*042d53a7SEvalZero
57*042d53a7SEvalZero void
print_addr(const void * addr)58*042d53a7SEvalZero print_addr(const void *addr)
59*042d53a7SEvalZero {
60*042d53a7SEvalZero const uint8_t *u8p;
61*042d53a7SEvalZero
62*042d53a7SEvalZero u8p = addr;
63*042d53a7SEvalZero console_printf("%02x:%02x:%02x:%02x:%02x:%02x",
64*042d53a7SEvalZero u8p[5], u8p[4], u8p[3], u8p[2], u8p[1], u8p[0]);
65*042d53a7SEvalZero }
66*042d53a7SEvalZero
67*042d53a7SEvalZero void
print_uuid(const ble_uuid_t * uuid)68*042d53a7SEvalZero print_uuid(const ble_uuid_t *uuid)
69*042d53a7SEvalZero {
70*042d53a7SEvalZero char buf[BLE_UUID_STR_LEN];
71*042d53a7SEvalZero
72*042d53a7SEvalZero ble_uuid_to_str(uuid, buf);
73*042d53a7SEvalZero
74*042d53a7SEvalZero console_printf("%s", buf);
75*042d53a7SEvalZero }
76*042d53a7SEvalZero
77*042d53a7SEvalZero int
svc_is_empty(const struct btshell_svc * svc)78*042d53a7SEvalZero svc_is_empty(const struct btshell_svc *svc)
79*042d53a7SEvalZero {
80*042d53a7SEvalZero return svc->svc.end_handle <= svc->svc.start_handle;
81*042d53a7SEvalZero }
82*042d53a7SEvalZero
83*042d53a7SEvalZero uint16_t
chr_end_handle(const struct btshell_svc * svc,const struct btshell_chr * chr)84*042d53a7SEvalZero chr_end_handle(const struct btshell_svc *svc, const struct btshell_chr *chr)
85*042d53a7SEvalZero {
86*042d53a7SEvalZero const struct btshell_chr *next_chr;
87*042d53a7SEvalZero
88*042d53a7SEvalZero next_chr = SLIST_NEXT(chr, next);
89*042d53a7SEvalZero if (next_chr != NULL) {
90*042d53a7SEvalZero return next_chr->chr.def_handle - 1;
91*042d53a7SEvalZero } else {
92*042d53a7SEvalZero return svc->svc.end_handle;
93*042d53a7SEvalZero }
94*042d53a7SEvalZero }
95*042d53a7SEvalZero
96*042d53a7SEvalZero int
chr_is_empty(const struct btshell_svc * svc,const struct btshell_chr * chr)97*042d53a7SEvalZero chr_is_empty(const struct btshell_svc *svc, const struct btshell_chr *chr)
98*042d53a7SEvalZero {
99*042d53a7SEvalZero return chr_end_handle(svc, chr) <= chr->chr.val_handle;
100*042d53a7SEvalZero }
101*042d53a7SEvalZero
102*042d53a7SEvalZero void
print_conn_desc(const struct ble_gap_conn_desc * desc)103*042d53a7SEvalZero print_conn_desc(const struct ble_gap_conn_desc *desc)
104*042d53a7SEvalZero {
105*042d53a7SEvalZero console_printf("handle=%d our_ota_addr_type=%d our_ota_addr=",
106*042d53a7SEvalZero desc->conn_handle, desc->our_ota_addr.type);
107*042d53a7SEvalZero print_addr(desc->our_ota_addr.val);
108*042d53a7SEvalZero console_printf(" our_id_addr_type=%d our_id_addr=",
109*042d53a7SEvalZero desc->our_id_addr.type);
110*042d53a7SEvalZero print_addr(desc->our_id_addr.val);
111*042d53a7SEvalZero console_printf(" peer_ota_addr_type=%d peer_ota_addr=",
112*042d53a7SEvalZero desc->peer_ota_addr.type);
113*042d53a7SEvalZero print_addr(desc->peer_ota_addr.val);
114*042d53a7SEvalZero console_printf(" peer_id_addr_type=%d peer_id_addr=",
115*042d53a7SEvalZero desc->peer_id_addr.type);
116*042d53a7SEvalZero print_addr(desc->peer_id_addr.val);
117*042d53a7SEvalZero console_printf(" conn_itvl=%d conn_latency=%d supervision_timeout=%d "
118*042d53a7SEvalZero "encrypted=%d authenticated=%d bonded=%d\n",
119*042d53a7SEvalZero desc->conn_itvl, desc->conn_latency,
120*042d53a7SEvalZero desc->supervision_timeout,
121*042d53a7SEvalZero desc->sec_state.encrypted,
122*042d53a7SEvalZero desc->sec_state.authenticated,
123*042d53a7SEvalZero desc->sec_state.bonded);
124*042d53a7SEvalZero }
125*042d53a7SEvalZero
126*042d53a7SEvalZero static void
print_dsc(struct btshell_dsc * dsc)127*042d53a7SEvalZero print_dsc(struct btshell_dsc *dsc)
128*042d53a7SEvalZero {
129*042d53a7SEvalZero console_printf(" dsc_handle=%d uuid=", dsc->dsc.handle);
130*042d53a7SEvalZero print_uuid(&dsc->dsc.uuid.u);
131*042d53a7SEvalZero console_printf("\n");
132*042d53a7SEvalZero }
133*042d53a7SEvalZero
134*042d53a7SEvalZero static void
print_chr(struct btshell_chr * chr)135*042d53a7SEvalZero print_chr(struct btshell_chr *chr)
136*042d53a7SEvalZero {
137*042d53a7SEvalZero struct btshell_dsc *dsc;
138*042d53a7SEvalZero
139*042d53a7SEvalZero console_printf(" def_handle=%d val_handle=%d properties=0x%02x "
140*042d53a7SEvalZero "uuid=", chr->chr.def_handle, chr->chr.val_handle,
141*042d53a7SEvalZero chr->chr.properties);
142*042d53a7SEvalZero print_uuid(&chr->chr.uuid.u);
143*042d53a7SEvalZero console_printf("\n");
144*042d53a7SEvalZero
145*042d53a7SEvalZero SLIST_FOREACH(dsc, &chr->dscs, next) {
146*042d53a7SEvalZero print_dsc(dsc);
147*042d53a7SEvalZero }
148*042d53a7SEvalZero }
149*042d53a7SEvalZero
150*042d53a7SEvalZero void
print_svc(struct btshell_svc * svc)151*042d53a7SEvalZero print_svc(struct btshell_svc *svc)
152*042d53a7SEvalZero {
153*042d53a7SEvalZero struct btshell_chr *chr;
154*042d53a7SEvalZero
155*042d53a7SEvalZero console_printf(" start=%d end=%d uuid=", svc->svc.start_handle,
156*042d53a7SEvalZero svc->svc.end_handle);
157*042d53a7SEvalZero print_uuid(&svc->svc.uuid.u);
158*042d53a7SEvalZero console_printf("\n");
159*042d53a7SEvalZero
160*042d53a7SEvalZero SLIST_FOREACH(chr, &svc->chrs, next) {
161*042d53a7SEvalZero print_chr(chr);
162*042d53a7SEvalZero }
163*042d53a7SEvalZero }
164