xref: /nrf52832-nimble/packages/NimBLE-latest/apps/blecent/src/misc.c (revision 042d53a763ad75cb1465103098bb88c245d95138)
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 <assert.h>
21*042d53a7SEvalZero #include <stdio.h>
22*042d53a7SEvalZero #include <string.h>
23*042d53a7SEvalZero #include "host/ble_hs.h"
24*042d53a7SEvalZero #include "host/ble_uuid.h"
25*042d53a7SEvalZero #include "blecent.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         MODLOG_DFLT(INFO, "%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             MODLOG_DFLT(INFO, ":");
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 char *
addr_str(const void * addr)58*042d53a7SEvalZero addr_str(const void *addr)
59*042d53a7SEvalZero {
60*042d53a7SEvalZero     static char buf[6 * 2 + 5 + 1];
61*042d53a7SEvalZero     const uint8_t *u8p;
62*042d53a7SEvalZero 
63*042d53a7SEvalZero     u8p = addr;
64*042d53a7SEvalZero     sprintf(buf, "%02x:%02x:%02x:%02x:%02x:%02x",
65*042d53a7SEvalZero             u8p[5], u8p[4], u8p[3], u8p[2], u8p[1], u8p[0]);
66*042d53a7SEvalZero 
67*042d53a7SEvalZero     return buf;
68*042d53a7SEvalZero }
69*042d53a7SEvalZero 
70*042d53a7SEvalZero void
print_uuid(const ble_uuid_t * uuid)71*042d53a7SEvalZero print_uuid(const ble_uuid_t *uuid)
72*042d53a7SEvalZero {
73*042d53a7SEvalZero     char buf[BLE_UUID_STR_LEN];
74*042d53a7SEvalZero 
75*042d53a7SEvalZero     MODLOG_DFLT(INFO, "%s", ble_uuid_to_str(uuid, buf));
76*042d53a7SEvalZero }
77*042d53a7SEvalZero 
78*042d53a7SEvalZero /**
79*042d53a7SEvalZero  * Logs information about a connection to the console.
80*042d53a7SEvalZero  */
81*042d53a7SEvalZero void
print_conn_desc(const struct ble_gap_conn_desc * desc)82*042d53a7SEvalZero print_conn_desc(const struct ble_gap_conn_desc *desc)
83*042d53a7SEvalZero {
84*042d53a7SEvalZero     MODLOG_DFLT(INFO, "handle=%d our_ota_addr_type=%d our_ota_addr=%s ",
85*042d53a7SEvalZero                 desc->conn_handle, desc->our_ota_addr.type,
86*042d53a7SEvalZero                 addr_str(desc->our_ota_addr.val));
87*042d53a7SEvalZero     MODLOG_DFLT(INFO, "our_id_addr_type=%d our_id_addr=%s ",
88*042d53a7SEvalZero                 desc->our_id_addr.type, addr_str(desc->our_id_addr.val));
89*042d53a7SEvalZero     MODLOG_DFLT(INFO, "peer_ota_addr_type=%d peer_ota_addr=%s ",
90*042d53a7SEvalZero                 desc->peer_ota_addr.type, addr_str(desc->peer_ota_addr.val));
91*042d53a7SEvalZero     MODLOG_DFLT(INFO, "peer_id_addr_type=%d peer_id_addr=%s ",
92*042d53a7SEvalZero                 desc->peer_id_addr.type, addr_str(desc->peer_id_addr.val));
93*042d53a7SEvalZero     MODLOG_DFLT(INFO, "conn_itvl=%d conn_latency=%d supervision_timeout=%d "
94*042d53a7SEvalZero                 "encrypted=%d authenticated=%d bonded=%d",
95*042d53a7SEvalZero                 desc->conn_itvl, desc->conn_latency,
96*042d53a7SEvalZero                 desc->supervision_timeout,
97*042d53a7SEvalZero                 desc->sec_state.encrypted,
98*042d53a7SEvalZero                 desc->sec_state.authenticated,
99*042d53a7SEvalZero                 desc->sec_state.bonded);
100*042d53a7SEvalZero }
101*042d53a7SEvalZero 
102*042d53a7SEvalZero 
103*042d53a7SEvalZero void
print_adv_fields(const struct ble_hs_adv_fields * fields)104*042d53a7SEvalZero print_adv_fields(const struct ble_hs_adv_fields *fields)
105*042d53a7SEvalZero {
106*042d53a7SEvalZero     char s[BLE_HS_ADV_MAX_SZ];
107*042d53a7SEvalZero     const uint8_t *u8p;
108*042d53a7SEvalZero     int i;
109*042d53a7SEvalZero 
110*042d53a7SEvalZero     if (fields->flags != 0) {
111*042d53a7SEvalZero         MODLOG_DFLT(INFO, "    flags=0x%02x\n", fields->flags);
112*042d53a7SEvalZero     }
113*042d53a7SEvalZero 
114*042d53a7SEvalZero     if (fields->uuids16 != NULL) {
115*042d53a7SEvalZero         MODLOG_DFLT(INFO, "    uuids16(%scomplete)=",
116*042d53a7SEvalZero                     fields->uuids16_is_complete ? "" : "in");
117*042d53a7SEvalZero         for (i = 0; i < fields->num_uuids16; i++) {
118*042d53a7SEvalZero             print_uuid(&fields->uuids16[i].u);
119*042d53a7SEvalZero             MODLOG_DFLT(INFO, " ");
120*042d53a7SEvalZero         }
121*042d53a7SEvalZero         MODLOG_DFLT(INFO, "\n");
122*042d53a7SEvalZero     }
123*042d53a7SEvalZero 
124*042d53a7SEvalZero     if (fields->uuids32 != NULL) {
125*042d53a7SEvalZero         MODLOG_DFLT(INFO, "    uuids32(%scomplete)=",
126*042d53a7SEvalZero                     fields->uuids32_is_complete ? "" : "in");
127*042d53a7SEvalZero         for (i = 0; i < fields->num_uuids32; i++) {
128*042d53a7SEvalZero             print_uuid(&fields->uuids32[i].u);
129*042d53a7SEvalZero             MODLOG_DFLT(INFO, " ");
130*042d53a7SEvalZero         }
131*042d53a7SEvalZero         MODLOG_DFLT(INFO, "\n");
132*042d53a7SEvalZero     }
133*042d53a7SEvalZero 
134*042d53a7SEvalZero     if (fields->uuids128 != NULL) {
135*042d53a7SEvalZero         MODLOG_DFLT(INFO, "    uuids128(%scomplete)=",
136*042d53a7SEvalZero                     fields->uuids128_is_complete ? "" : "in");
137*042d53a7SEvalZero         for (i = 0; i < fields->num_uuids128; i++) {
138*042d53a7SEvalZero             print_uuid(&fields->uuids128[i].u);
139*042d53a7SEvalZero             MODLOG_DFLT(INFO, " ");
140*042d53a7SEvalZero         }
141*042d53a7SEvalZero         MODLOG_DFLT(INFO, "\n");
142*042d53a7SEvalZero     }
143*042d53a7SEvalZero 
144*042d53a7SEvalZero     if (fields->name != NULL) {
145*042d53a7SEvalZero         assert(fields->name_len < sizeof s - 1);
146*042d53a7SEvalZero         memcpy(s, fields->name, fields->name_len);
147*042d53a7SEvalZero         s[fields->name_len] = '\0';
148*042d53a7SEvalZero         MODLOG_DFLT(INFO, "    name(%scomplete)=%s\n",
149*042d53a7SEvalZero                     fields->name_is_complete ? "" : "in", s);
150*042d53a7SEvalZero     }
151*042d53a7SEvalZero 
152*042d53a7SEvalZero     if (fields->tx_pwr_lvl_is_present) {
153*042d53a7SEvalZero         MODLOG_DFLT(INFO, "    tx_pwr_lvl=%d\n", fields->tx_pwr_lvl);
154*042d53a7SEvalZero     }
155*042d53a7SEvalZero 
156*042d53a7SEvalZero     if (fields->slave_itvl_range != NULL) {
157*042d53a7SEvalZero         MODLOG_DFLT(INFO, "    slave_itvl_range=");
158*042d53a7SEvalZero         print_bytes(fields->slave_itvl_range, BLE_HS_ADV_SLAVE_ITVL_RANGE_LEN);
159*042d53a7SEvalZero         MODLOG_DFLT(INFO, "\n");
160*042d53a7SEvalZero     }
161*042d53a7SEvalZero 
162*042d53a7SEvalZero     if (fields->svc_data_uuid16 != NULL) {
163*042d53a7SEvalZero         MODLOG_DFLT(INFO, "    svc_data_uuid16=");
164*042d53a7SEvalZero         print_bytes(fields->svc_data_uuid16, fields->svc_data_uuid16_len);
165*042d53a7SEvalZero         MODLOG_DFLT(INFO, "\n");
166*042d53a7SEvalZero     }
167*042d53a7SEvalZero 
168*042d53a7SEvalZero     if (fields->public_tgt_addr != NULL) {
169*042d53a7SEvalZero         MODLOG_DFLT(INFO, "    public_tgt_addr=");
170*042d53a7SEvalZero         u8p = fields->public_tgt_addr;
171*042d53a7SEvalZero         for (i = 0; i < fields->num_public_tgt_addrs; i++) {
172*042d53a7SEvalZero             MODLOG_DFLT(INFO, "public_tgt_addr=%s ", addr_str(u8p));
173*042d53a7SEvalZero             u8p += BLE_HS_ADV_PUBLIC_TGT_ADDR_ENTRY_LEN;
174*042d53a7SEvalZero         }
175*042d53a7SEvalZero         MODLOG_DFLT(INFO, "\n");
176*042d53a7SEvalZero     }
177*042d53a7SEvalZero 
178*042d53a7SEvalZero     if (fields->appearance_is_present) {
179*042d53a7SEvalZero         MODLOG_DFLT(INFO, "    appearance=0x%04x\n", fields->appearance);
180*042d53a7SEvalZero     }
181*042d53a7SEvalZero 
182*042d53a7SEvalZero     if (fields->adv_itvl_is_present) {
183*042d53a7SEvalZero         MODLOG_DFLT(INFO, "    adv_itvl=0x%04x\n", fields->adv_itvl);
184*042d53a7SEvalZero     }
185*042d53a7SEvalZero 
186*042d53a7SEvalZero     if (fields->svc_data_uuid32 != NULL) {
187*042d53a7SEvalZero         MODLOG_DFLT(INFO, "    svc_data_uuid32=");
188*042d53a7SEvalZero         print_bytes(fields->svc_data_uuid32, fields->svc_data_uuid32_len);
189*042d53a7SEvalZero         MODLOG_DFLT(INFO, "\n");
190*042d53a7SEvalZero     }
191*042d53a7SEvalZero 
192*042d53a7SEvalZero     if (fields->svc_data_uuid128 != NULL) {
193*042d53a7SEvalZero         MODLOG_DFLT(INFO, "    svc_data_uuid128=");
194*042d53a7SEvalZero         print_bytes(fields->svc_data_uuid128, fields->svc_data_uuid128_len);
195*042d53a7SEvalZero         MODLOG_DFLT(INFO, "\n");
196*042d53a7SEvalZero     }
197*042d53a7SEvalZero 
198*042d53a7SEvalZero     if (fields->uri != NULL) {
199*042d53a7SEvalZero         MODLOG_DFLT(INFO, "    uri=");
200*042d53a7SEvalZero         print_bytes(fields->uri, fields->uri_len);
201*042d53a7SEvalZero         MODLOG_DFLT(INFO, "\n");
202*042d53a7SEvalZero     }
203*042d53a7SEvalZero 
204*042d53a7SEvalZero     if (fields->mfg_data != NULL) {
205*042d53a7SEvalZero         MODLOG_DFLT(INFO, "    mfg_data=");
206*042d53a7SEvalZero         print_bytes(fields->mfg_data, fields->mfg_data_len);
207*042d53a7SEvalZero         MODLOG_DFLT(INFO, "\n");
208*042d53a7SEvalZero     }
209*042d53a7SEvalZero }
210