i = GET_U_1(cp);
cp++;
while (i) {
- if ((i & INDIR_MASK) == INDIR_MASK)
+ switch (i & TYPE_MASK) {
+
+ case TYPE_INDIR:
return (cp + 1);
- if ((i & INDIR_MASK) == EDNS0_MASK) {
+
+ case TYPE_EDNS0: {
int bitlen, bytelen;
- if ((i & ~INDIR_MASK) != EDNS0_ELT_BITLABEL)
+ if ((i & ~TYPE_MASK) != EDNS0_ELT_BITLABEL)
return(NULL); /* unknown ELT */
if (!ND_TTEST_1(cp))
return (NULL);
cp++;
bytelen = (bitlen + 7) / 8;
cp += bytelen;
- } else
+ }
+ break;
+
+ case TYPE_RESERVED:
+ return (NULL);
+
+ case TYPE_LABEL:
cp += i;
+ break;
+ }
if (!ND_TTEST_1(cp))
return (NULL);
i = GET_U_1(cp);
/* print the bit string as a hex string */
ND_PRINT("\\[x");
for (bitp = cp + 1, b = bitlen; bitp < lim && b > 7; b -= 8, bitp++) {
- ND_TCHECK_1(bitp);
ND_PRINT("%02x", GET_U_1(bitp));
}
if (b > 4) {
- ND_TCHECK_1(bitp);
tc = GET_U_1(bitp);
bitp++;
ND_PRINT("%02x", tc & (0xff << (8 - b)));
} else if (b > 0) {
- ND_TCHECK_1(bitp);
tc = GET_U_1(bitp);
bitp++;
ND_PRINT("%1x", ((tc >> 4) & 0x0f) & (0x0f << (4 - b)));
}
ND_PRINT("/%u]", bitlen);
return lim;
-trunc:
- ND_PRINT(".../%u]", bitlen);
- return NULL;
}
static int
if (!ND_TTEST_1(cp))
return(-1);
i = GET_U_1(cp);
- if ((i & INDIR_MASK) == EDNS0_MASK) {
+ switch (i & TYPE_MASK) {
+
+ case TYPE_EDNS0: {
u_int bitlen, elt;
- if ((elt = (i & ~INDIR_MASK)) != EDNS0_ELT_BITLABEL) {
+ if ((elt = (i & ~TYPE_MASK)) != EDNS0_ELT_BITLABEL) {
ND_PRINT("<ELT %d>", elt);
return(-1);
}
if ((bitlen = GET_U_1(cp + 1)) == 0)
bitlen = 256;
return(((bitlen + 7) / 8) + 1);
- } else
+ }
+
+ case TYPE_INDIR:
+ case TYPE_LABEL:
return(i);
+
+ default:
+ /*
+ * TYPE_RESERVED, but we use default to suppress compiler
+ * warnings about falling out of the switch statement.
+ */
+ ND_PRINT("<BAD LABEL TYPE>");
+ return(-1);
+ }
}
/* print a <domain-name> */
int compress = 0;
u_int elt;
u_int offset, max_offset;
+ u_int name_chars = 0;
if ((l = labellen(ndo, cp)) == (u_int)-1)
return(NULL);
max_offset = (u_int)(cp - bp);
i = GET_U_1(cp);
cp++;
- if ((i & INDIR_MASK) != INDIR_MASK) {
+ if ((i & TYPE_MASK) != TYPE_INDIR) {
compress = 0;
rp = cp + l;
}
- if (i != 0)
+ if (i != 0) {
while (i && cp < ndo->ndo_snapend) {
- if ((i & INDIR_MASK) == INDIR_MASK) {
+ switch (i & TYPE_MASK) {
+
+ case TYPE_INDIR:
if (!compress) {
rp = cp + 1;
compress = 1;
}
max_offset = offset;
cp = bp + offset;
- if ((l = labellen(ndo, cp)) == (u_int)-1)
- return(NULL);
if (!ND_TTEST_1(cp))
return(NULL);
i = GET_U_1(cp);
+ if ((l = labellen(ndo, cp)) == (u_int)-1)
+ return(NULL);
cp++;
continue;
- }
- if ((i & INDIR_MASK) == EDNS0_MASK) {
- elt = (i & ~INDIR_MASK);
+
+ case TYPE_EDNS0:
+ elt = (i & ~TYPE_MASK);
switch(elt) {
case EDNS0_ELT_BITLABEL:
if (blabel_print(ndo, cp) == NULL)
ND_PRINT("<ELT %u>", elt);
return(NULL);
}
- } else {
- if (nd_printn(ndo, cp, l, ndo->ndo_snapend))
- return(NULL);
+ break;
+
+ case TYPE_RESERVED:
+ ND_PRINT("<BAD LABEL TYPE>");
+ return(NULL);
+
+ case TYPE_LABEL:
+ if (name_chars + l <= MAXCDNAME) {
+ if (nd_printn(ndo, cp, l, ndo->ndo_snapend))
+ return(NULL);
+ } else if (name_chars < MAXCDNAME) {
+ if (nd_printn(ndo, cp,
+ MAXCDNAME - name_chars, ndo->ndo_snapend))
+ return(NULL);
+ }
+ name_chars += l;
+ break;
}
cp += l;
- ND_PRINT(".");
- if ((l = labellen(ndo, cp)) == (u_int)-1)
- return(NULL);
+ if (name_chars <= MAXCDNAME)
+ ND_PRINT(".");
+ name_chars++;
if (!ND_TTEST_1(cp))
return(NULL);
i = GET_U_1(cp);
+ if ((l = labellen(ndo, cp)) == (u_int)-1)
+ return(NULL);
cp++;
if (!compress)
rp += l + 1;
}
- else
+ if (name_chars > MAXCDNAME)
+ ND_PRINT("<DOMAIN NAME TOO LONG>");
+ } else
ND_PRINT(".");
return (rp);
}
case T_NS:
case T_CNAME:
case T_PTR:
-#ifdef T_DNAME
case T_DNAME:
-#endif
ND_PRINT(" ");
if (fqdn_print(ndo, cp, bp) == NULL)
return(NULL);
ND_PRINT(" %u(bad plen)", pbit);
break;
} else if (pbit < 128) {
- if (!ND_TTEST_LEN(cp + 1, sizeof(a) - pbyte))
- return(NULL);
memset(a, 0, sizeof(a));
- memcpy(a + pbyte, cp + 1, sizeof(a) - pbyte);
+ GET_CPY_BYTES(a + pbyte, cp + 1, sizeof(a) - pbyte);
ND_PRINT(" %u %s", pbit,
addrtostr6(&a, ntop_buf, sizeof(ntop_buf)));
}
if (cp + 1 > ndo->ndo_snapend)
goto print;
if (type == T_OPT) {
- rcode |= (*cp << 4);
+ rcode |= (GET_U_1(cp) << 4);
goto print;
}
cp += 4;