coap_get_log_level:
  103|    356|coap_get_log_level(void) {
  104|    356|  return maxlog;
  105|    356|}
coap_log_level_desc:
  124|    356|coap_log_level_desc(coap_log_t level) {
  125|    356|  static char bad[8];
  126|    356|  if (level >= sizeof(loglevels)/sizeof(loglevels[0])) {
  ------------------
  |  Branch (126:7): [True: 0, False: 356]
  ------------------
  127|      0|    snprintf(bad, sizeof(bad), "%4d", level);
  128|      0|    return bad;
  129|    356|  } else {
  130|    356|    return loglevels[level];
  131|    356|  }
  132|    356|}
coap_log_impl:
 1343|    356|coap_log_impl(coap_log_t level, const char *format, ...) {
 1344|       |
 1345|       |#if COAP_THREAD_SAFE
 1346|       |  coap_mutex_lock(&m_log_impl);
 1347|       |#endif /* COAP_THREAD_SAFE */
 1348|       |
 1349|    356|  if (log_handler) {
  ------------------
  |  Branch (1349:7): [True: 0, False: 356]
  ------------------
 1350|       |#if COAP_CONSTRAINED_STACK
 1351|       |    /* message can be protected by m_log_impl if needed */
 1352|       |    static char message[COAP_DEBUG_BUF_SIZE];
 1353|       |#else /* ! COAP_CONSTRAINED_STACK */
 1354|      0|    char message[COAP_DEBUG_BUF_SIZE];
 1355|      0|#endif /* ! COAP_CONSTRAINED_STACK */
 1356|      0|    va_list ap;
 1357|      0|    va_start(ap, format);
 1358|       |
 1359|       |#ifdef RIOT_VERSION
 1360|       |    flash_vsnprintf(message, sizeof(message), format, ap);
 1361|       |#else /* !RIOT_VERSION */
 1362|      0|    vsnprintf(message, sizeof(message), format, ap);
 1363|      0|#endif /* !RIOT_VERSION */
 1364|      0|    va_end(ap);
 1365|      0|    log_handler(level, message);
 1366|    356|  } else {
 1367|    356|    char timebuf[32];
 1368|    356|    coap_tick_t now;
 1369|    356|    va_list ap;
 1370|    356|    FILE *log_fd;
 1371|    356|    size_t len;
 1372|       |
 1373|    356|    log_fd = level <= COAP_LOG_CRIT ? COAP_ERR_FD : COAP_DEBUG_FD;
  ------------------
  |  |   44|    356|#define COAP_ERR_FD stderr
  ------------------
                  log_fd = level <= COAP_LOG_CRIT ? COAP_ERR_FD : COAP_DEBUG_FD;
  ------------------
  |  |   37|    356|#define COAP_DEBUG_FD stdout
  ------------------
  |  Branch (1373:14): [True: 0, False: 356]
  ------------------
 1374|       |
 1375|    356|    coap_ticks(&now);
 1376|    356|    len = print_timestamp(timebuf,sizeof(timebuf), now);
 1377|    356|    if (len)
  ------------------
  |  Branch (1377:9): [True: 356, False: 0]
  ------------------
 1378|    356|      fprintf(log_fd, "%.*s ", (int)len, timebuf);
 1379|       |
 1380|       |#if COAP_THREAD_SAFE && COAP_THREAD_NUM_LOGGING
 1381|       |    if (thread_no == 0) {
 1382|       |      /*
 1383|       |       * All other call to coap_mutex_lock(&m_io_threads) immediately
 1384|       |       * by setting thread_no if 0. So deadlock should never occur.
 1385|       |       */
 1386|       |      coap_mutex_lock(&m_io_threads);
 1387|       |      thread_no = ++max_thread_no;
 1388|       |      coap_mutex_unlock(&m_io_threads);
 1389|       |    }
 1390|       |    fprintf(log_fd, "%2d ", thread_no);
 1391|       |#endif /* COAP_THREAD_SAFE && COAP_THREAD_NUM_LOGGING */
 1392|       |
 1393|    356|    fprintf(log_fd, "%s ", coap_log_level_desc(level));
 1394|       |
 1395|    356|    va_start(ap, format);
 1396|       |#ifdef RIOT_VERSION
 1397|       |    flash_vfprintf(log_fd, format, ap);
 1398|       |#else /* !RIOT_VERSION */
 1399|    356|    vfprintf(log_fd, format, ap);
 1400|    356|#endif /* !RIOT_VERSION */
 1401|    356|    va_end(ap);
 1402|    356|    fflush(log_fd);
 1403|    356|  }
 1404|       |
 1405|       |#if COAP_THREAD_SAFE
 1406|       |  coap_mutex_unlock(&m_log_impl);
 1407|       |#endif /* COAP_THREAD_SAFE */
 1408|    356|}
coap_debug.c:print_timestamp:
  144|    356|print_timestamp(char *s, size_t len, coap_tick_t t) {
  145|    356|  struct tm *tmp;
  146|    356|  size_t lensofar;
  147|    356|  time_t now = coap_ticks_to_rt(t);
  148|    356|  tmp = localtime(&now);
  149|    356|  lensofar = strftime(s, len, "%b %d %H:%M:%S", tmp);
  150|    356|  if (len > lensofar + 4) {
  ------------------
  |  Branch (150:7): [True: 356, False: 0]
  ------------------
  151|    356|    lensofar += snprintf(&s[lensofar], len-lensofar, ".%03u",
  152|    356|                         (unsigned int)((coap_ticks_to_rt_us(t) % 1000000)/1000));
  153|    356|  }
  154|    356|  return lensofar;
  155|    356|}

coap_dtls_is_supported:
  188|      1|coap_dtls_is_supported(void) {
  189|      1|  if (SSLeay() < 0x10100000L) {
  ------------------
  |  Branch (189:7): [True: 0, False: 1]
  ------------------
  190|      0|    coap_log_warn("OpenSSL version 1.1.0 or later is required\n");
  ------------------
  |  |  108|      0|#define coap_log_warn(...) coap_log(COAP_LOG_WARN, __VA_ARGS__)
  |  |  ------------------
  |  |  |  |  290|      0|#define coap_log(level, ...) do { \
  |  |  |  |  291|      0|    if ((level) < (coap_get_log_level() + 1)) \
  |  |  |  |  ------------------
  |  |  |  |  |  Branch (291:9): [True: 0, False: 0]
  |  |  |  |  ------------------
  |  |  |  |  292|      0|      coap_log_impl((level), __VA_ARGS__); \
  |  |  |  |  293|      0|  } while(0)
  |  |  |  |  ------------------
  |  |  |  |  |  Branch (293:11): [Folded, False: 0]
  |  |  |  |  ------------------
  |  |  ------------------
  ------------------
  191|      0|    return 0;
  192|      0|  }
  193|      1|#if OPENSSL_VERSION_NUMBER >= 0x10101000L
  194|       |  /*
  195|       |   * For 1.1.1, we need to use SSL_CTX_set_client_hello_cb()
  196|       |   * which is not in 1.1.0 instead of SSL_CTX_set_tlsext_servername_callback()
  197|       |   *
  198|       |   * However, there could be a runtime undefined external reference error
  199|       |   * as SSL_CTX_set_client_hello_cb() is not there in 1.1.0.
  200|       |   */
  201|      1|  if (SSLeay() < 0x10101000L) {
  ------------------
  |  Branch (201:7): [True: 0, False: 1]
  ------------------
  202|      0|    coap_log_warn("OpenSSL version 1.1.1 or later is required\n");
  ------------------
  |  |  108|      0|#define coap_log_warn(...) coap_log(COAP_LOG_WARN, __VA_ARGS__)
  |  |  ------------------
  |  |  |  |  290|      0|#define coap_log(level, ...) do { \
  |  |  |  |  291|      0|    if ((level) < (coap_get_log_level() + 1)) \
  |  |  |  |  ------------------
  |  |  |  |  |  Branch (291:9): [True: 0, False: 0]
  |  |  |  |  ------------------
  |  |  |  |  292|      0|      coap_log_impl((level), __VA_ARGS__); \
  |  |  |  |  293|      0|  } while(0)
  |  |  |  |  ------------------
  |  |  |  |  |  Branch (293:11): [Folded, False: 0]
  |  |  |  |  ------------------
  |  |  ------------------
  ------------------
  203|      0|    return 0;
  204|      0|  }
  205|      1|#endif /* OPENSSL_VERSION_NUMBER >= 0x10101000L */
  206|      1|  return 1;
  207|      1|}
coap_tls_is_supported:
  210|      2|coap_tls_is_supported(void) {
  211|      2|#if !COAP_DISABLE_TCP
  212|      2|  if (SSLeay() < 0x10100000L) {
  ------------------
  |  Branch (212:7): [True: 0, False: 2]
  ------------------
  213|      0|    coap_log_warn("OpenSSL version 1.1.0 or later is required\n");
  ------------------
  |  |  108|      0|#define coap_log_warn(...) coap_log(COAP_LOG_WARN, __VA_ARGS__)
  |  |  ------------------
  |  |  |  |  290|      0|#define coap_log(level, ...) do { \
  |  |  |  |  291|      0|    if ((level) < (coap_get_log_level() + 1)) \
  |  |  |  |  ------------------
  |  |  |  |  |  Branch (291:9): [True: 0, False: 0]
  |  |  |  |  ------------------
  |  |  |  |  292|      0|      coap_log_impl((level), __VA_ARGS__); \
  |  |  |  |  293|      0|  } while(0)
  |  |  |  |  ------------------
  |  |  |  |  |  Branch (293:11): [Folded, False: 0]
  |  |  |  |  ------------------
  |  |  ------------------
  ------------------
  214|      0|    return 0;
  215|      0|  }
  216|      2|#if OPENSSL_VERSION_NUMBER >= 0x10101000L
  217|      2|  if (SSLeay() < 0x10101000L) {
  ------------------
  |  Branch (217:7): [True: 0, False: 2]
  ------------------
  218|      0|    coap_log_warn("OpenSSL version 1.1.1 or later is required\n");
  ------------------
  |  |  108|      0|#define coap_log_warn(...) coap_log(COAP_LOG_WARN, __VA_ARGS__)
  |  |  ------------------
  |  |  |  |  290|      0|#define coap_log(level, ...) do { \
  |  |  |  |  291|      0|    if ((level) < (coap_get_log_level() + 1)) \
  |  |  |  |  ------------------
  |  |  |  |  |  Branch (291:9): [True: 0, False: 0]
  |  |  |  |  ------------------
  |  |  |  |  292|      0|      coap_log_impl((level), __VA_ARGS__); \
  |  |  |  |  293|      0|  } while(0)
  |  |  |  |  ------------------
  |  |  |  |  |  Branch (293:11): [Folded, False: 0]
  |  |  |  |  ------------------
  |  |  ------------------
  ------------------
  219|      0|    return 0;
  220|      0|  }
  221|      2|#endif /* OPENSSL_VERSION_NUMBER >= 0x10101000L */
  222|      2|  return 1;
  223|       |#else /* COAP_DISABLE_TCP */
  224|       |  return 0;
  225|       |#endif /* COAP_DISABLE_TCP */
  226|      2|}

coap_tcp_is_supported:
   35|      2|coap_tcp_is_supported(void) {
   36|      2|  return !COAP_DISABLE_TCP;
  ------------------
  |  |   23|      2|#define COAP_DISABLE_TCP 0
  ------------------
   37|      2|}

coap_ticks:
   90|    356|coap_ticks(coap_tick_t *t) {
   91|    356|  coap_tick_t tmp;
   92|       |
   93|    356|#ifdef COAP_CLOCK
   94|    356|  struct timespec tv;
   95|    356|  clock_gettime(COAP_CLOCK, &tv);
  ------------------
  |  |   43|    356|#define COAP_CLOCK CLOCK_REALTIME
  ------------------
   96|       |  /* Possible errors are (see clock_gettime(2)):
   97|       |   *  EFAULT tp points outside the accessible address space.
   98|       |   *  EINVAL The clk_id specified is not supported on this system.
   99|       |   * Both cases should not be possible here.
  100|       |   */
  101|       |
  102|    356|  tmp = SHR_FP(tv.tv_nsec * Q(FRAC, (COAP_TICKS_PER_SECOND/1000000000.0)), FRAC);
  ------------------
  |  |   87|    356|#define SHR_FP(val,frac) (((coap_tick_t)((val) + (1 << ((frac) - 1)))) >> (frac))
  ------------------
  103|       |#else /* _POSIX_TIMERS */
  104|       |  /* Fall back to gettimeofday() */
  105|       |
  106|       |  struct timeval tv;
  107|       |  gettimeofday(&tv, NULL);
  108|       |  /* Possible errors are (see gettimeofday(2)):
  109|       |   *  EFAULT One of tv or tz pointed outside the accessible address space.
  110|       |   *  EINVAL Timezone (or something else) is invalid.
  111|       |   * Both cases should not be possible here.
  112|       |   */
  113|       |
  114|       |  tmp = SHR_FP(tv.tv_usec * Q(FRAC, (COAP_TICKS_PER_SECOND/1000000.0)), FRAC);
  115|       |#endif /* not _POSIX_TIMERS */
  116|       |
  117|       |  /* Finally, convert temporary FP representation to multiple of
  118|       |   * COAP_TICKS_PER_SECOND */
  119|    356|  *t = tmp + (tv.tv_sec - coap_clock_offset) * COAP_TICKS_PER_SECOND;
  ------------------
  |  |  164|    356|#define COAP_TICKS_PER_SECOND ((coap_tick_t)(1000U))
  ------------------
  120|    356|}
coap_ticks_to_rt:
  123|    356|coap_ticks_to_rt(coap_tick_t t) {
  124|    356|  return coap_clock_offset + (t / COAP_TICKS_PER_SECOND);
  ------------------
  |  |  164|    356|#define COAP_TICKS_PER_SECOND ((coap_tick_t)(1000U))
  ------------------
  125|    356|}
coap_ticks_to_rt_us:
  128|    356|coap_ticks_to_rt_us(coap_tick_t t) {
  129|    356|  return (uint64_t)coap_clock_offset * 1000000 + (uint64_t)t * 1000000 / COAP_TICKS_PER_SECOND;
  ------------------
  |  |  164|    356|#define COAP_TICKS_PER_SECOND ((coap_tick_t)(1000U))
  ------------------
  130|    356|}

coap_split_uri:
  346|    821|coap_split_uri(const uint8_t *str_var, size_t len, coap_uri_t *uri) {
  347|    821|  return coap_split_uri_sub(str_var, len, uri, COAP_URI_CHECK_URI);
  348|    821|}
coap_uri.c:coap_split_uri_sub:
   84|    821|                   coap_uri_check_t check_proxy) {
   85|    821|  const uint8_t *p, *q;
   86|    821|  int res = 0;
   87|    821|  size_t i;
   88|    821|  int is_unix_domain = 0;
   89|    821|  int is_llc = 0;
   90|       |
   91|    821|  if (!str_var || !uri || len == 0)
  ------------------
  |  Branch (91:7): [True: 0, False: 821]
  |  Branch (91:19): [True: 0, False: 821]
  |  Branch (91:27): [True: 0, False: 821]
  ------------------
   92|      0|    return -1;
   93|       |
   94|    821|  memset(uri, 0, sizeof(coap_uri_t));
   95|    821|  uri->port = COAP_DEFAULT_PORT;
  ------------------
  |  |   39|    821|#define COAP_DEFAULT_PORT      5683 /* CoAP default UDP/TCP port */
  ------------------
   96|       |
   97|       |  /* search for scheme */
   98|    821|  p = str_var;
   99|    821|  if (*p == '/') {
  ------------------
  |  Branch (99:7): [True: 75, False: 746]
  ------------------
  100|       |    /* no scheme, host or port */
  101|     75|    if (check_proxy == COAP_URI_CHECK_PROXY) {
  ------------------
  |  Branch (101:9): [True: 0, False: 75]
  ------------------
  102|       |      /* Must have ongoing host if proxy definition */
  103|      0|      return -1;
  104|      0|    }
  105|     75|    q = p;
  106|     75|    goto path;
  107|     75|  }
  108|       |
  109|       |  /* find scheme terminating :// */
  110|  10.7M|  while (len >= 3 && !(p[0] == ':' && p[1] == '/' && p[2] == '/')) {
  ------------------
  |  Branch (110:10): [True: 10.7M, False: 68]
  |  Branch (110:24): [True: 3.97k, False: 10.7M]
  |  Branch (110:39): [True: 936, False: 3.04k]
  |  Branch (110:54): [True: 678, False: 258]
  ------------------
  111|  10.7M|    ++p;
  112|  10.7M|    --len;
  113|  10.7M|  }
  114|    746|  if (len < 3) {
  ------------------
  |  Branch (114:7): [True: 68, False: 678]
  ------------------
  115|       |    /* scheme not defined with a :// terminator */
  116|     68|    res = -2;
  117|     68|    goto error;
  118|     68|  }
  119|  1.78k|  for (i = 0; i < COAP_URI_SCHEME_LAST; i++) {
  ------------------
  |  Branch (119:15): [True: 1.64k, False: 135]
  ------------------
  120|  1.64k|    if ((p - str_var) == (int)strlen(coap_uri_scheme[i].name) &&
  ------------------
  |  Branch (120:9): [True: 671, False: 975]
  ------------------
  121|    671|        memcmp(str_var, coap_uri_scheme[i].name, p - str_var) == 0) {
  ------------------
  |  Branch (121:9): [True: 543, False: 128]
  ------------------
  122|    543|      if (check_proxy != COAP_URI_CHECK_PROXY && coap_uri_scheme[i].proxy_only) {
  ------------------
  |  Branch (122:11): [True: 543, False: 0]
  |  Branch (122:50): [True: 1, False: 542]
  ------------------
  123|      1|        coap_log_err("%.*s URI scheme not enabled (not a proxy)\n",
  ------------------
  |  |  102|      1|#define coap_log_err(...) coap_log(COAP_LOG_ERR, __VA_ARGS__)
  |  |  ------------------
  |  |  |  |  290|      1|#define coap_log(level, ...) do { \
  |  |  |  |  291|      1|    if ((level) < (coap_get_log_level() + 1)) \
  |  |  |  |  ------------------
  |  |  |  |  |  Branch (291:9): [True: 1, False: 0]
  |  |  |  |  ------------------
  |  |  |  |  292|      1|      coap_log_impl((level), __VA_ARGS__); \
  |  |  |  |  293|      1|  } while(0)
  |  |  |  |  ------------------
  |  |  |  |  |  Branch (293:11): [Folded, False: 1]
  |  |  |  |  ------------------
  |  |  ------------------
  ------------------
  124|      1|                     (int)(p - str_var), str_var);
  125|      1|        return -1;
  126|      1|      }
  127|    542|      uri->scheme = coap_uri_scheme[i].scheme;
  128|    542|      uri->port = coap_uri_scheme[i].port;
  129|    542|      break;
  130|    543|    }
  131|  1.64k|  }
  132|    677|  if (i == COAP_URI_SCHEME_LAST) {
  ------------------
  |  Branch (132:7): [True: 135, False: 542]
  ------------------
  133|       |    /* scheme unknown */
  134|    135|    coap_log_err("%.*s URI scheme unknown\n", (int)(p - str_var), str_var);
  ------------------
  |  |  102|    135|#define coap_log_err(...) coap_log(COAP_LOG_ERR, __VA_ARGS__)
  |  |  ------------------
  |  |  |  |  290|    135|#define coap_log(level, ...) do { \
  |  |  |  |  291|    135|    if ((level) < (coap_get_log_level() + 1)) \
  |  |  |  |  ------------------
  |  |  |  |  |  Branch (291:9): [True: 135, False: 0]
  |  |  |  |  ------------------
  |  |  |  |  292|    135|      coap_log_impl((level), __VA_ARGS__); \
  |  |  |  |  293|    135|  } while(0)
  |  |  |  |  ------------------
  |  |  |  |  |  Branch (293:11): [Folded, False: 135]
  |  |  |  |  ------------------
  |  |  ------------------
  ------------------
  135|    135|    res = -1;
  136|    135|    goto error;
  137|    135|  }
  138|    542|  switch (uri->scheme) {
  139|    537|  case COAP_URI_SCHEME_COAP:
  ------------------
  |  Branch (139:3): [True: 537, False: 5]
  ------------------
  140|    537|    break;
  141|      1|  case COAP_URI_SCHEME_COAPS:
  ------------------
  |  Branch (141:3): [True: 1, False: 541]
  ------------------
  142|      1|    if (!coap_dtls_is_supported()) {
  ------------------
  |  Branch (142:9): [True: 0, False: 1]
  ------------------
  143|      0|      coap_log_err("coaps URI scheme not supported in this version of libcoap\n");
  ------------------
  |  |  102|      0|#define coap_log_err(...) coap_log(COAP_LOG_ERR, __VA_ARGS__)
  |  |  ------------------
  |  |  |  |  290|      0|#define coap_log(level, ...) do { \
  |  |  |  |  291|      0|    if ((level) < (coap_get_log_level() + 1)) \
  |  |  |  |  ------------------
  |  |  |  |  |  Branch (291:9): [True: 0, False: 0]
  |  |  |  |  ------------------
  |  |  |  |  292|      0|      coap_log_impl((level), __VA_ARGS__); \
  |  |  |  |  293|      0|  } while(0)
  |  |  |  |  ------------------
  |  |  |  |  |  Branch (293:11): [Folded, False: 0]
  |  |  |  |  ------------------
  |  |  ------------------
  ------------------
  144|      0|      return -1;
  145|      0|    }
  146|      1|    break;
  147|      1|  case COAP_URI_SCHEME_COAP_TCP:
  ------------------
  |  Branch (147:3): [True: 1, False: 541]
  ------------------
  148|      1|    if (!coap_tcp_is_supported()) {
  ------------------
  |  Branch (148:9): [True: 0, False: 1]
  ------------------
  149|      0|      coap_log_err("coap+tcp URI scheme not supported in this version of libcoap\n");
  ------------------
  |  |  102|      0|#define coap_log_err(...) coap_log(COAP_LOG_ERR, __VA_ARGS__)
  |  |  ------------------
  |  |  |  |  290|      0|#define coap_log(level, ...) do { \
  |  |  |  |  291|      0|    if ((level) < (coap_get_log_level() + 1)) \
  |  |  |  |  ------------------
  |  |  |  |  |  Branch (291:9): [True: 0, False: 0]
  |  |  |  |  ------------------
  |  |  |  |  292|      0|      coap_log_impl((level), __VA_ARGS__); \
  |  |  |  |  293|      0|  } while(0)
  |  |  |  |  ------------------
  |  |  |  |  |  Branch (293:11): [Folded, False: 0]
  |  |  |  |  ------------------
  |  |  ------------------
  ------------------
  150|      0|      return -1;
  151|      0|    }
  152|      1|    break;
  153|      1|  case COAP_URI_SCHEME_COAPS_TCP:
  ------------------
  |  Branch (153:3): [True: 1, False: 541]
  ------------------
  154|      1|    if (!coap_tls_is_supported()) {
  ------------------
  |  Branch (154:9): [True: 0, False: 1]
  ------------------
  155|      0|      coap_log_err("coaps+tcp URI scheme not supported in this version of libcoap\n");
  ------------------
  |  |  102|      0|#define coap_log_err(...) coap_log(COAP_LOG_ERR, __VA_ARGS__)
  |  |  ------------------
  |  |  |  |  290|      0|#define coap_log(level, ...) do { \
  |  |  |  |  291|      0|    if ((level) < (coap_get_log_level() + 1)) \
  |  |  |  |  ------------------
  |  |  |  |  |  Branch (291:9): [True: 0, False: 0]
  |  |  |  |  ------------------
  |  |  |  |  292|      0|      coap_log_impl((level), __VA_ARGS__); \
  |  |  |  |  293|      0|  } while(0)
  |  |  |  |  ------------------
  |  |  |  |  |  Branch (293:11): [Folded, False: 0]
  |  |  |  |  ------------------
  |  |  ------------------
  ------------------
  156|      0|      return -1;
  157|      0|    }
  158|      1|    break;
  159|      1|  case COAP_URI_SCHEME_COAP_WS:
  ------------------
  |  Branch (159:3): [True: 1, False: 541]
  ------------------
  160|      1|    if (!coap_ws_is_supported()) {
  ------------------
  |  Branch (160:9): [True: 0, False: 1]
  ------------------
  161|      0|      coap_log_err("coap+ws URI scheme not supported in this version of libcoap\n");
  ------------------
  |  |  102|      0|#define coap_log_err(...) coap_log(COAP_LOG_ERR, __VA_ARGS__)
  |  |  ------------------
  |  |  |  |  290|      0|#define coap_log(level, ...) do { \
  |  |  |  |  291|      0|    if ((level) < (coap_get_log_level() + 1)) \
  |  |  |  |  ------------------
  |  |  |  |  |  Branch (291:9): [True: 0, False: 0]
  |  |  |  |  ------------------
  |  |  |  |  292|      0|      coap_log_impl((level), __VA_ARGS__); \
  |  |  |  |  293|      0|  } while(0)
  |  |  |  |  ------------------
  |  |  |  |  |  Branch (293:11): [Folded, False: 0]
  |  |  |  |  ------------------
  |  |  ------------------
  ------------------
  162|      0|      return -1;
  163|      0|    }
  164|      1|    break;
  165|      1|  case COAP_URI_SCHEME_COAPS_WS:
  ------------------
  |  Branch (165:3): [True: 1, False: 541]
  ------------------
  166|      1|    if (!coap_wss_is_supported()) {
  ------------------
  |  Branch (166:9): [True: 0, False: 1]
  ------------------
  167|      0|      coap_log_err("coaps+ws URI scheme not supported in this version of libcoap\n");
  ------------------
  |  |  102|      0|#define coap_log_err(...) coap_log(COAP_LOG_ERR, __VA_ARGS__)
  |  |  ------------------
  |  |  |  |  290|      0|#define coap_log(level, ...) do { \
  |  |  |  |  291|      0|    if ((level) < (coap_get_log_level() + 1)) \
  |  |  |  |  ------------------
  |  |  |  |  |  Branch (291:9): [True: 0, False: 0]
  |  |  |  |  ------------------
  |  |  |  |  292|      0|      coap_log_impl((level), __VA_ARGS__); \
  |  |  |  |  293|      0|  } while(0)
  |  |  |  |  ------------------
  |  |  |  |  |  Branch (293:11): [Folded, False: 0]
  |  |  |  |  ------------------
  |  |  ------------------
  ------------------
  168|      0|      return -1;
  169|      0|    }
  170|      1|    break;
  171|      1|  case COAP_URI_SCHEME_HTTP:
  ------------------
  |  Branch (171:3): [True: 0, False: 542]
  ------------------
  172|      0|  case COAP_URI_SCHEME_HTTPS:
  ------------------
  |  Branch (172:3): [True: 0, False: 542]
  ------------------
  173|       |    /* Not proxy, caught above.  For proxy, assume app is doing CoAP <> HTTP mapping. */
  174|      0|    break;
  175|      0|  case COAP_URI_SCHEME_LAST:
  ------------------
  |  Branch (175:3): [True: 0, False: 542]
  ------------------
  176|      0|  default:
  ------------------
  |  Branch (176:3): [True: 0, False: 542]
  ------------------
  177|      0|    coap_log_warn("Unsupported URI type %d\n", uri->scheme);
  ------------------
  |  |  108|      0|#define coap_log_warn(...) coap_log(COAP_LOG_WARN, __VA_ARGS__)
  |  |  ------------------
  |  |  |  |  290|      0|#define coap_log(level, ...) do { \
  |  |  |  |  291|      0|    if ((level) < (coap_get_log_level() + 1)) \
  |  |  |  |  ------------------
  |  |  |  |  |  Branch (291:9): [True: 0, False: 0]
  |  |  |  |  ------------------
  |  |  |  |  292|      0|      coap_log_impl((level), __VA_ARGS__); \
  |  |  |  |  293|      0|  } while(0)
  |  |  |  |  ------------------
  |  |  |  |  |  Branch (293:11): [Folded, False: 0]
  |  |  |  |  ------------------
  |  |  ------------------
  ------------------
  178|      0|    return -1;
  179|    542|  }
  180|       |  /* skip :// */
  181|    542|  p += 3;
  182|    542|  len -= 3;
  183|       |
  184|       |  /* p points to beginning of Uri-Host */
  185|    542|  q = p;
  186|       |
  187|    542|  if (len && *p == '[') {
  ------------------
  |  Branch (187:7): [True: 536, False: 6]
  |  Branch (187:14): [True: 68, False: 468]
  ------------------
  188|       |    /* IPv6 address reference or Unix domain */
  189|     68|    ++p;
  190|     68|    ++q;
  191|     68|    --len;
  192|       |
  193|  3.03M|    while (len && *q != ']') {
  ------------------
  |  Branch (193:12): [True: 3.03M, False: 27]
  |  Branch (193:19): [True: 3.03M, False: 41]
  ------------------
  194|  3.03M|      ++q;
  195|  3.03M|      --len;
  196|  3.03M|    }
  197|       |
  198|     68|    if (!len || *q != ']' || p == q) {
  ------------------
  |  Branch (198:9): [True: 27, False: 41]
  |  Branch (198:17): [True: 0, False: 41]
  |  Branch (198:30): [True: 2, False: 39]
  ------------------
  199|     29|      res = -3;
  200|     29|      goto error;
  201|     29|    }
  202|       |
  203|     39|    COAP_SET_STR(&uri->host, q - p, p);
  ------------------
  |  |   52|     39|#define COAP_SET_STR(st,l,v) { (st)->length = (l), (st)->s = (v); }
  ------------------
  204|     39|    ++q;
  205|     39|    --len;
  206|     39|#if COAP_AF_LLC_SUPPORT
  207|    474|  } else if ((len >= LLC_HOST_LEN) && strncmp((const char *)p, "llc[", 4) == 0) {
  ------------------
  |  |  169|    474|#define LLC_HOST_LEN (4 + HW_ADDRSTRLEN + 4)
  |  |  ------------------
  |  |  |  |  167|    474|#define HW_ADDRSTRLEN 17
  |  |  ------------------
  ------------------
  |  Branch (207:14): [True: 324, False: 150]
  |  Branch (207:39): [True: 174, False: 150]
  ------------------
  208|    174|    unsigned long sap = 0;
  209|       |
  210|    174|    is_llc = 1;
  211|       |
  212|  1.58M|    while (len && *q != ']') {
  ------------------
  |  Branch (212:12): [True: 1.58M, False: 7]
  |  Branch (212:19): [True: 1.58M, False: 167]
  ------------------
  213|  1.58M|      ++q;
  214|  1.58M|      --len;
  215|  1.58M|    }
  216|       |
  217|    174|    if (!len || *q != ']' || p == q) {
  ------------------
  |  Branch (217:9): [True: 7, False: 167]
  |  Branch (217:17): [True: 0, False: 167]
  |  Branch (217:30): [True: 0, False: 167]
  ------------------
  218|      7|      res = -7;
  219|      7|      goto error;
  220|      7|    }
  221|       |
  222|    167|    ++q;
  223|    167|    --len;
  224|       |
  225|    167|    if (!len || *q != ':') {
  ------------------
  |  Branch (225:9): [True: 8, False: 159]
  |  Branch (225:17): [True: 24, False: 135]
  ------------------
  226|     32|      coap_log_warn("LLC SAP missing in URI\n");
  ------------------
  |  |  108|     32|#define coap_log_warn(...) coap_log(COAP_LOG_WARN, __VA_ARGS__)
  |  |  ------------------
  |  |  |  |  290|     32|#define coap_log(level, ...) do { \
  |  |  |  |  291|     32|    if ((level) < (coap_get_log_level() + 1)) \
  |  |  |  |  ------------------
  |  |  |  |  |  Branch (291:9): [True: 32, False: 0]
  |  |  |  |  ------------------
  |  |  |  |  292|     32|      coap_log_impl((level), __VA_ARGS__); \
  |  |  |  |  293|     32|  } while(0)
  |  |  |  |  ------------------
  |  |  |  |  |  Branch (293:11): [Folded, False: 32]
  |  |  |  |  ------------------
  |  |  ------------------
  ------------------
  227|     32|      res = -7;
  228|     32|      goto error;
  229|     32|    }
  230|       |
  231|    135|    ++q;
  232|    135|    --len;
  233|       |
  234|  19.5k|    while (len && isxdigit(*q)) {
  ------------------
  |  Branch (234:12): [True: 19.4k, False: 51]
  |  Branch (234:19): [True: 19.3k, False: 84]
  ------------------
  235|  19.3k|      if (*q >= 'a' && *q <= 'f')
  ------------------
  |  Branch (235:11): [True: 1.21k, False: 18.1k]
  |  Branch (235:24): [True: 1.21k, False: 0]
  ------------------
  236|  1.21k|        sap = sap * 16 + (*q - 'a' + 10);
  237|  18.1k|      else if (*q >= 'A' && *q <= 'F')
  ------------------
  |  Branch (237:16): [True: 1.12k, False: 17.0k]
  |  Branch (237:29): [True: 1.12k, False: 0]
  ------------------
  238|  1.12k|        sap = sap * 16 + (*q - 'A' + 10);
  239|       |
  240|  19.3k|      ++q;
  241|  19.3k|      --len;
  242|  19.3k|    }
  243|       |
  244|    135|    if (sap > UINT8_MAX) {
  ------------------
  |  Branch (244:9): [True: 105, False: 30]
  ------------------
  245|    105|      coap_log_warn("LLC SAP invalid (%lu > 255)\n", sap);
  ------------------
  |  |  108|    105|#define coap_log_warn(...) coap_log(COAP_LOG_WARN, __VA_ARGS__)
  |  |  ------------------
  |  |  |  |  290|    105|#define coap_log(level, ...) do { \
  |  |  |  |  291|    105|    if ((level) < (coap_get_log_level() + 1)) \
  |  |  |  |  ------------------
  |  |  |  |  |  Branch (291:9): [True: 105, False: 0]
  |  |  |  |  ------------------
  |  |  |  |  292|    105|      coap_log_impl((level), __VA_ARGS__); \
  |  |  |  |  293|    105|  } while(0)
  |  |  |  |  ------------------
  |  |  |  |  |  Branch (293:11): [Folded, False: 105]
  |  |  |  |  ------------------
  |  |  ------------------
  ------------------
  246|    105|      res = -7;
  247|    105|      goto error;
  248|    105|    }
  249|       |
  250|     30|    COAP_SET_STR(&uri->host, q - p, p);
  ------------------
  |  |   52|     30|#define COAP_SET_STR(st,l,v) { (st)->length = (l), (st)->s = (v); }
  ------------------
  251|     30|#endif /* COAP_AF_LLC_SUPPORT */
  252|    300|  } else {
  253|       |    /* IPv4 address, FQDN or Unix domain socket */
  254|    300|    if (len >= 3 && p[0] == '%' && p[1] == '2' &&
  ------------------
  |  Branch (254:9): [True: 266, False: 34]
  |  Branch (254:21): [True: 39, False: 227]
  |  Branch (254:36): [True: 19, False: 20]
  ------------------
  255|     19|        (p[2] == 'F' || p[2] == 'f')) {
  ------------------
  |  Branch (255:10): [True: 2, False: 17]
  |  Branch (255:25): [True: 2, False: 15]
  ------------------
  256|       |      /* Unix domain definition */
  257|      4|      uri->port = 0;
  258|      4|      is_unix_domain = 1;
  259|      4|    }
  260|  5.18M|    while (len && *q != ':' && *q != '/' && *q != '?') {
  ------------------
  |  Branch (260:12): [True: 5.18M, False: 123]
  |  Branch (260:19): [True: 5.18M, False: 165]
  |  Branch (260:32): [True: 5.18M, False: 9]
  |  Branch (260:45): [True: 5.18M, False: 3]
  ------------------
  261|  5.18M|      ++q;
  262|  5.18M|      --len;
  263|  5.18M|    }
  264|       |
  265|    300|    if (p == q) {
  ------------------
  |  Branch (265:9): [True: 10, False: 290]
  ------------------
  266|     10|      res = -3;
  267|     10|      goto error;
  268|     10|    }
  269|       |
  270|    290|    if ((int)(q - p) > 255) {
  ------------------
  |  Branch (270:9): [True: 34, False: 256]
  ------------------
  271|     34|      coap_log_warn("Host name length too long (%d > 255)\n", (int)(q - p));
  ------------------
  |  |  108|     34|#define coap_log_warn(...) coap_log(COAP_LOG_WARN, __VA_ARGS__)
  |  |  ------------------
  |  |  |  |  290|     34|#define coap_log(level, ...) do { \
  |  |  |  |  291|     34|    if ((level) < (coap_get_log_level() + 1)) \
  |  |  |  |  ------------------
  |  |  |  |  |  Branch (291:9): [True: 34, False: 0]
  |  |  |  |  ------------------
  |  |  |  |  292|     34|      coap_log_impl((level), __VA_ARGS__); \
  |  |  |  |  293|     34|  } while(0)
  |  |  |  |  ------------------
  |  |  |  |  |  Branch (293:11): [Folded, False: 34]
  |  |  |  |  ------------------
  |  |  ------------------
  ------------------
  272|     34|      res = -6;
  273|     34|      goto error;
  274|     34|    }
  275|       |
  276|    256|    COAP_SET_STR(&uri->host, q - p, p);
  ------------------
  |  |   52|    256|#define COAP_SET_STR(st,l,v) { (st)->length = (l), (st)->s = (v); }
  ------------------
  277|    256|  }
  278|       |
  279|       |  /* check for Uri-Port (invalid for Unix) */
  280|    325|  if (len && *q == ':') {
  ------------------
  |  Branch (280:7): [True: 209, False: 116]
  |  Branch (280:14): [True: 165, False: 44]
  ------------------
  281|    165|    if (is_unix_domain || is_llc) {
  ------------------
  |  Branch (281:9): [True: 2, False: 163]
  |  Branch (281:27): [True: 1, False: 162]
  ------------------
  282|      3|      res = -5;
  283|      3|      goto error;
  284|      3|    }
  285|    162|    p = ++q;
  286|    162|    --len;
  287|       |
  288|  1.62M|    while (len && isdigit(*q)) {
  ------------------
  |  Branch (288:12): [True: 1.62M, False: 85]
  |  Branch (288:19): [True: 1.62M, False: 77]
  ------------------
  289|  1.62M|      ++q;
  290|  1.62M|      --len;
  291|  1.62M|    }
  292|       |
  293|    162|    if (p < q) {                /* explicit port number given */
  ------------------
  |  Branch (293:9): [True: 121, False: 41]
  ------------------
  294|    121|      long uri_port = 0;
  295|       |
  296|   185k|      while ((p < q) && (uri_port <= UINT16_MAX))
  ------------------
  |  Branch (296:14): [True: 185k, False: 94]
  |  Branch (296:25): [True: 185k, False: 27]
  ------------------
  297|   185k|        uri_port = uri_port * 10 + (*p++ - '0');
  298|       |
  299|       |      /* check if port number is in allowed range */
  300|    121|      if (uri_port > UINT16_MAX) {
  ------------------
  |  Branch (300:11): [True: 49, False: 72]
  ------------------
  301|     49|        coap_log_warn("Port number too big (%ld > 65535)\n", uri_port);
  ------------------
  |  |  108|     49|#define coap_log_warn(...) coap_log(COAP_LOG_WARN, __VA_ARGS__)
  |  |  ------------------
  |  |  |  |  290|     49|#define coap_log(level, ...) do { \
  |  |  |  |  291|     49|    if ((level) < (coap_get_log_level() + 1)) \
  |  |  |  |  ------------------
  |  |  |  |  |  Branch (291:9): [True: 49, False: 0]
  |  |  |  |  ------------------
  |  |  |  |  292|     49|      coap_log_impl((level), __VA_ARGS__); \
  |  |  |  |  293|     49|  } while(0)
  |  |  |  |  ------------------
  |  |  |  |  |  Branch (293:11): [Folded, False: 49]
  |  |  |  |  ------------------
  |  |  ------------------
  ------------------
  302|     49|        res = -4;
  303|     49|        goto error;
  304|     49|      }
  305|       |
  306|     72|      uri->port = (uint16_t)uri_port;
  307|     72|    }
  308|    162|  }
  309|       |
  310|    348|path:                 /* at this point, p must point to an absolute path */
  311|       |
  312|    348|  if (!len)
  ------------------
  |  Branch (312:7): [True: 162, False: 186]
  ------------------
  313|    162|    goto end;
  314|       |
  315|    186|  if (*q == '/') {
  ------------------
  |  Branch (315:7): [True: 93, False: 93]
  ------------------
  316|     93|    p = ++q;
  317|     93|    --len;
  318|       |
  319|  6.83M|    while (len && *q != '?') {
  ------------------
  |  Branch (319:12): [True: 6.83M, False: 67]
  |  Branch (319:19): [True: 6.83M, False: 26]
  ------------------
  320|  6.83M|      ++q;
  321|  6.83M|      --len;
  322|  6.83M|    }
  323|       |
  324|     93|    if (p < q) {
  ------------------
  |  Branch (324:9): [True: 66, False: 27]
  ------------------
  325|     66|      COAP_SET_STR(&uri->path, q - p, p);
  ------------------
  |  |   52|     66|#define COAP_SET_STR(st,l,v) { (st)->length = (l), (st)->s = (v); }
  ------------------
  326|     66|      p = q;
  327|     66|    }
  328|     93|  }
  329|       |
  330|       |  /* Uri_Query */
  331|    186|  if (len && *p == '?') {
  ------------------
  |  Branch (331:7): [True: 119, False: 67]
  |  Branch (331:14): [True: 26, False: 93]
  ------------------
  332|     26|    ++p;
  333|     26|    --len;
  334|     26|    COAP_SET_STR(&uri->query, len, p);
  ------------------
  |  |   52|     26|#define COAP_SET_STR(st,l,v) { (st)->length = (l), (st)->s = (v); }
  ------------------
  335|     26|    len = 0;
  336|     26|  }
  337|       |
  338|    348|end:
  339|    348|  return len ? -1 : 0;
  ------------------
  |  Branch (339:10): [True: 93, False: 255]
  ------------------
  340|       |
  341|    472|error:
  342|    472|  return res;
  343|    186|}

coap_ws_is_supported:
   38|      1|coap_ws_is_supported(void) {
   39|      1|  return coap_tcp_is_supported();
   40|      1|}
coap_wss_is_supported:
   43|      1|coap_wss_is_supported(void) {
   44|      1|  return coap_tls_is_supported();
   45|      1|}

LLVMFuzzerTestOneInput:
    4|    821|LLVMFuzzerTestOneInput(const uint8_t *data, size_t size) {
    5|    821|  coap_uri_t uri;
    6|    821|  coap_split_uri(data, size, &uri);
    7|    821|  return 0;
    8|    821|}

