* Find an NSEC3PARAM with a supported algorithm.
*/
raw = dns_slabheader_raw(found);
- count = raw[0] * 256 + raw[1]; /* count */
- raw += DNS_RDATASET_LENGTH;
+ count = get_uint16(raw);
while (count-- > 0U) {
dns_rdata_t rdata = DNS_RDATA_INIT;
- length = raw[0] * 256 + raw[1];
- raw += DNS_RDATASET_LENGTH;
+
+ length = get_uint16(raw);
region.base = raw;
region.length = length;
raw += length;
REQUIRE(header->typepair == DNS_TYPEPAIR(dns_rdatatype_nsec3));
raw = (unsigned char *)header + sizeof(*header);
- count = raw[0] * 256 + raw[1]; /* count */
- raw += DNS_RDATASET_LENGTH;
+ count = get_uint16(raw);
while (count-- > 0) {
dns_rdata_t rdata = DNS_RDATA_INIT;
- rdlen = raw[0] * 256 + raw[1];
- raw += DNS_RDATASET_LENGTH;
+ rdlen = get_uint16(raw);
region.base = raw;
region.length = rdlen;
dns_rdata_fromregion(&rdata, search->qpdb->common.rdclass,
* When a slab is created, data records are sorted into DNSSEC order.
*/
-#define peek_uint16(buffer) ({ ((uint16_t)*(buffer) << 8) | *((buffer) + 1); })
-#define get_uint16(buffer) \
- ({ \
- uint16_t __ret = peek_uint16(buffer); \
- buffer += sizeof(uint16_t); \
- __ret; \
- })
-#define put_uint16(buffer, val) \
- ({ \
- *buffer++ = (val & 0xff00) >> 8; \
- *buffer++ = (val & 0x00ff); \
- })
-
static void
rdataset_disassociate(dns_rdataset_t *rdataset DNS__DB_FLARG);
static isc_result_t
#define ZEROTTL(header) \
((atomic_load_acquire(&(header)->attributes) & \
DNS_SLABHEADERATTR_ZEROTTL) != 0)
+
+#define peek_uint16(buffer) ({ ((uint16_t)*(buffer) << 8) | *((buffer) + 1); })
+#define get_uint16(buffer) \
+ ({ \
+ uint16_t __ret = peek_uint16(buffer); \
+ buffer += sizeof(uint16_t); \
+ __ret; \
+ })
+#define put_uint16(buffer, val) \
+ ({ \
+ *buffer++ = (val & 0xff00) >> 8; \
+ *buffer++ = (val & 0x00ff); \
+ })