#include "bench_harness.h"
#include "bench_utils.h"
#include <stdint.h>
#include <stdlib.h>
#include <string.h>
static inline uint64_t fnv1a_update(uint64_t h, const char *s, int len) {
  for (int i = 0; i < len; i++) {
    h ^= (uint64_t)(unsigned char)s[i];
    h *= 1099511628211ULL;
  }
  return h;
}
static inline int read_name(const uint8_t *msg, int msg_len, int start,
                            char *out, int out_cap, int *adv_bytes) {
  int pos = start;
  int jumped = 0;
  int endpos = -1;
  int outlen = 0;
  int steps = 0;
  for (;;) {
    if (steps++ > 256)
      break;
    if (pos >= msg_len)
      break;
    uint8_t len = msg[pos];
    if ((len & 0xC0u) == 0xC0u) {
      if (pos + 1 >= msg_len) {
        if (!jumped)
          endpos = pos + 2;
        break;
      }
      uint16_t off = ((uint16_t)(len & 0x3Fu) << 8) | (uint16_t)msg[pos + 1];
      if (!jumped)
        endpos = pos + 2;
      pos = (int)off;
      jumped = 1;
      continue;
    }
    if (len == 0) {
      if (!jumped)
        endpos = pos + 1;
      break;
    }
    pos++;
    if (outlen > 0 && outlen < out_cap) {
      out[outlen++] = '.';
    }
    for (int i = 0; i < len && pos + i < msg_len; i++) {
      if (outlen < out_cap)
        out[outlen++] = (char)msg[pos + i];
    }
    pos += len;
  }
  if (outlen < out_cap)
    out[outlen] = '\0';
  else
    out[out_cap - 1] = '\0';
  if (endpos < 0)
    endpos = start;
  *adv_bytes = endpos - start;
  return outlen;
}
static double dns_run(const uint8_t *msg, int msg_len, int qn) {
  uint64_t h = 1469598103934665603ULL;
  int pos = 0;
  for (int qi = 0; qi < qn; qi++) {
    char namebuf[256];
    int adv = 0;
    read_name(msg, msg_len, pos, namebuf, 256, &adv);
    if (adv <= 0)
      break;
    h = fnv1a_update(h, namebuf, (int)strlen(namebuf));
    pos += adv;
    if (pos + 4 > msg_len)
      break;
    pos += 4;
  }
  double ans_once = (double)h;
  double ans = 0.0;

  ans = ans_once;
  return ans;
}
BENCH_MAIN_SCALAR3(T004_Module_059, DNSDEC, 4096, 16384, 65536,
                   uint8_t *msg = (uint8_t *)malloc((size_t)n * 8 + 64);
                   double ans_scalar = 0.0;
                   , ({
                     bench_rng64_t rng = bench_rng_init(seed);
                     const uint8_t base_name[] = {3,   'w', 'w', 'w', 7,   'e',
                                                  'x', 'a', 'm', 'p', 'l', 'e',
                                                  3,   'c', 'o', 'm', 0};
                     int qn = n / 16;
                     if (qn < 2)
                       qn = 2;
                     int pos = 0;
                     memcpy(msg + pos, base_name, sizeof(base_name));
                     pos += (int)sizeof(base_name);
                     msg[pos++] = 0x00;
                     msg[pos++] = 0x01;
                     msg[pos++] = 0x00;
                     msg[pos++] = 0x01;
                     for (int i = 1; i < qn; i++) {
                       msg[pos++] = 0xC0u;
                       msg[pos++] = 0x00u;
                       msg[pos++] = 0x00;
                       msg[pos++] = 0x01;
                       msg[pos++] = 0x00;
                       msg[pos++] = 0x01;
                     }
                     n = pos;
                   }),
                   ans_scalar = dns_run(msg, n, (n >= 4 ? (n / 6) : 1)),
                   ans_scalar, free(msg);)
