misc.c 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198
  1. /*
  2. * SPDX-FileCopyrightText: 2015-2021 Espressif Systems (Shanghai) CO LTD
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. */
  6. #include <assert.h>
  7. #include <stdio.h>
  8. #include <string.h>
  9. #include "host/ble_hs.h"
  10. #include "host/ble_uuid.h"
  11. #include "gattc.h"
  12. /**
  13. * Utility function to log an array of bytes.
  14. */
  15. void
  16. print_bytes(const uint8_t *bytes, int len)
  17. {
  18. int i;
  19. for (i = 0; i < len; i++) {
  20. MODLOG_DFLT(DEBUG, "%s0x%02x", i != 0 ? ":" : "", bytes[i]);
  21. }
  22. }
  23. void
  24. print_mbuf(const struct os_mbuf *om)
  25. {
  26. int colon, i;
  27. colon = 0;
  28. while (om != NULL) {
  29. if (colon) {
  30. MODLOG_DFLT(INFO, ":");
  31. } else {
  32. colon = 1;
  33. }
  34. for (i = 0; i < om->om_len; i++) {
  35. MODLOG_DFLT(INFO, "%s0x%02x", i != 0 ? ":" : "", om->om_data[i]);
  36. }
  37. om = SLIST_NEXT(om, om_next);
  38. }
  39. }
  40. char *
  41. addr_str(const void *addr)
  42. {
  43. static char buf[6 * 2 + 5 + 1];
  44. const uint8_t *u8p;
  45. u8p = addr;
  46. sprintf(buf, "%02x:%02x:%02x:%02x:%02x:%02x",
  47. u8p[5], u8p[4], u8p[3], u8p[2], u8p[1], u8p[0]);
  48. return buf;
  49. }
  50. void
  51. print_uuid(const ble_uuid_t *uuid)
  52. {
  53. char buf[BLE_UUID_STR_LEN];
  54. MODLOG_DFLT(DEBUG, "%s", ble_uuid_to_str(uuid, buf));
  55. }
  56. /**
  57. * Logs information about a connection to the console.
  58. */
  59. void
  60. print_conn_desc(const struct ble_gap_conn_desc *desc)
  61. {
  62. MODLOG_DFLT(DEBUG, "handle=%d our_ota_addr_type=%d our_ota_addr=%s ",
  63. desc->conn_handle, desc->our_ota_addr.type,
  64. addr_str(desc->our_ota_addr.val));
  65. MODLOG_DFLT(DEBUG, "our_id_addr_type=%d our_id_addr=%s ",
  66. desc->our_id_addr.type, addr_str(desc->our_id_addr.val));
  67. MODLOG_DFLT(DEBUG, "peer_ota_addr_type=%d peer_ota_addr=%s ",
  68. desc->peer_ota_addr.type, addr_str(desc->peer_ota_addr.val));
  69. MODLOG_DFLT(DEBUG, "peer_id_addr_type=%d peer_id_addr=%s ",
  70. desc->peer_id_addr.type, addr_str(desc->peer_id_addr.val));
  71. MODLOG_DFLT(DEBUG, "conn_itvl=%d conn_latency=%d supervision_timeout=%d "
  72. "encrypted=%d authenticated=%d bonded=%d",
  73. desc->conn_itvl, desc->conn_latency,
  74. desc->supervision_timeout,
  75. desc->sec_state.encrypted,
  76. desc->sec_state.authenticated,
  77. desc->sec_state.bonded);
  78. }
  79. void
  80. print_adv_fields(const struct ble_hs_adv_fields *fields)
  81. {
  82. char s[BLE_HS_ADV_MAX_SZ];
  83. const uint8_t *u8p;
  84. int i;
  85. if (fields->flags != 0) {
  86. MODLOG_DFLT(DEBUG, " flags=0x%02x\n", fields->flags);
  87. }
  88. if (fields->uuids16 != NULL) {
  89. MODLOG_DFLT(DEBUG, " uuids16(%scomplete)=",
  90. fields->uuids16_is_complete ? "" : "in");
  91. for (i = 0; i < fields->num_uuids16; i++) {
  92. print_uuid(&fields->uuids16[i].u);
  93. MODLOG_DFLT(DEBUG, " ");
  94. }
  95. MODLOG_DFLT(DEBUG, "\n");
  96. }
  97. if (fields->uuids32 != NULL) {
  98. MODLOG_DFLT(DEBUG, " uuids32(%scomplete)=",
  99. fields->uuids32_is_complete ? "" : "in");
  100. for (i = 0; i < fields->num_uuids32; i++) {
  101. print_uuid(&fields->uuids32[i].u);
  102. MODLOG_DFLT(DEBUG, " ");
  103. }
  104. MODLOG_DFLT(DEBUG, "\n");
  105. }
  106. if (fields->uuids128 != NULL) {
  107. MODLOG_DFLT(DEBUG, " uuids128(%scomplete)=",
  108. fields->uuids128_is_complete ? "" : "in");
  109. for (i = 0; i < fields->num_uuids128; i++) {
  110. print_uuid(&fields->uuids128[i].u);
  111. MODLOG_DFLT(DEBUG, " ");
  112. }
  113. MODLOG_DFLT(DEBUG, "\n");
  114. }
  115. if (fields->name != NULL) {
  116. assert(fields->name_len < sizeof s - 1);
  117. memcpy(s, fields->name, fields->name_len);
  118. s[fields->name_len] = '\0';
  119. MODLOG_DFLT(DEBUG, " name(%scomplete)=%s\n",
  120. fields->name_is_complete ? "" : "in", s);
  121. }
  122. if (fields->tx_pwr_lvl_is_present) {
  123. MODLOG_DFLT(DEBUG, " tx_pwr_lvl=%d\n", fields->tx_pwr_lvl);
  124. }
  125. if (fields->slave_itvl_range != NULL) {
  126. MODLOG_DFLT(DEBUG, " slave_itvl_range=");
  127. print_bytes(fields->slave_itvl_range, BLE_HS_ADV_SLAVE_ITVL_RANGE_LEN);
  128. MODLOG_DFLT(DEBUG, "\n");
  129. }
  130. if (fields->svc_data_uuid16 != NULL) {
  131. MODLOG_DFLT(DEBUG, " svc_data_uuid16=");
  132. print_bytes(fields->svc_data_uuid16, fields->svc_data_uuid16_len);
  133. MODLOG_DFLT(DEBUG, "\n");
  134. }
  135. if (fields->public_tgt_addr != NULL) {
  136. MODLOG_DFLT(DEBUG, " public_tgt_addr=");
  137. u8p = fields->public_tgt_addr;
  138. for (i = 0; i < fields->num_public_tgt_addrs; i++) {
  139. MODLOG_DFLT(DEBUG, "public_tgt_addr=%s ", addr_str(u8p));
  140. u8p += BLE_HS_ADV_PUBLIC_TGT_ADDR_ENTRY_LEN;
  141. }
  142. MODLOG_DFLT(DEBUG, "\n");
  143. }
  144. if (fields->appearance_is_present) {
  145. MODLOG_DFLT(DEBUG, " appearance=0x%04x\n", fields->appearance);
  146. }
  147. if (fields->adv_itvl_is_present) {
  148. MODLOG_DFLT(DEBUG, " adv_itvl=0x%04x\n", fields->adv_itvl);
  149. }
  150. if (fields->svc_data_uuid32 != NULL) {
  151. MODLOG_DFLT(DEBUG, " svc_data_uuid32=");
  152. print_bytes(fields->svc_data_uuid32, fields->svc_data_uuid32_len);
  153. MODLOG_DFLT(DEBUG, "\n");
  154. }
  155. if (fields->svc_data_uuid128 != NULL) {
  156. MODLOG_DFLT(DEBUG, " svc_data_uuid128=");
  157. print_bytes(fields->svc_data_uuid128, fields->svc_data_uuid128_len);
  158. MODLOG_DFLT(DEBUG, "\n");
  159. }
  160. if (fields->uri != NULL) {
  161. MODLOG_DFLT(DEBUG, " uri=");
  162. print_bytes(fields->uri, fields->uri_len);
  163. MODLOG_DFLT(DEBUG, "\n");
  164. }
  165. if (fields->mfg_data != NULL) {
  166. MODLOG_DFLT(DEBUG, " mfg_data=");
  167. print_bytes(fields->mfg_data, fields->mfg_data_len);
  168. MODLOG_DFLT(DEBUG, "\n");
  169. }
  170. }