From 22bd0404f255d4013ad2dae1438906d5e90cfc14 Mon Sep 17 00:00:00 2001 From: Laurent Bercot Date: Sat, 2 Jan 2021 23:58:03 +0000 Subject: Prepare for 2.3.4.0 --- src/libs6dns/s6dns_message_parse_question.c | 10 +++++++--- 1 file changed, 7 insertions(+), 3 deletions(-) (limited to 'src') diff --git a/src/libs6dns/s6dns_message_parse_question.c b/src/libs6dns/s6dns_message_parse_question.c index 170168c..780ec22 100644 --- a/src/libs6dns/s6dns_message_parse_question.c +++ b/src/libs6dns/s6dns_message_parse_question.c @@ -8,15 +8,19 @@ #include #include -int s6dns_message_parse_question (s6dns_message_counts_t *counts, s6dns_domain_t *name, uint16_t *qtype, char const *packet, unsigned int packetlen, unsigned int *pos) +int s6dns_message_parse_question (s6dns_message_counts_t *counts, s6dns_domain_t *name, uint16_t *qtypep, char const *packet, unsigned int packetlen, unsigned int *pos) { + s6dns_domain_t d ; + uint16_t qtype ; uint16_t qclass ; if (!counts->qd) return (errno = EINVAL, 0) ; - if (!s6dns_message_get_domain(name, packet, packetlen, pos)) return 0 ; + if (!s6dns_message_get_domain(&d, packet, packetlen, pos)) return 0 ; if (*pos + 4 > packetlen) return (errno = EPROTO, 0) ; - uint16_unpack_big(packet + *pos, qtype) ; *pos += 2 ; + uint16_unpack_big(packet + *pos, &qtype) ; *pos += 2 ; uint16_unpack_big(packet + *pos, &qclass) ; *pos += 2 ; if (qclass != S6DNS_C_IN) return (errno = ENOTSUP, 0) ; counts->qd-- ; + *name = d ; + *qtypep = qtype ; return 1 ; } -- cgit v1.2.3