From: Yu Watanabe Date: Sat, 10 Dec 2022 01:21:41 +0000 (+0900) Subject: resolve: drop recursion in TXT field handling X-Git-Tag: v253-rc1~318^2~2 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=494ef1674334bfb3b4b574cb24d447bc4e7986ab;p=thirdparty%2Fsystemd.git resolve: drop recursion in TXT field handling Fixes #25683. --- diff --git a/src/resolve/resolved-dns-rr.c b/src/resolve/resolved-dns-rr.c index a4ba6bdc6d0..5f890f95093 100644 --- a/src/resolve/resolved-dns-rr.c +++ b/src/resolve/resolved-dns-rr.c @@ -1768,36 +1768,30 @@ int dns_resource_record_get_cname_target(DnsResourceKey *key, DnsResourceRecord return 0; } -DnsTxtItem *dns_txt_item_free_all(DnsTxtItem *i) { - DnsTxtItem *n; - - if (!i) - return NULL; - - n = i->items_next; +DnsTxtItem *dns_txt_item_free_all(DnsTxtItem *first) { + LIST_FOREACH(items, i, first) + free(i); - free(i); - return dns_txt_item_free_all(n); + return NULL; } bool dns_txt_item_equal(DnsTxtItem *a, DnsTxtItem *b) { + DnsTxtItem *bb = b; if (a == b) return true; - if (!a != !b) - return false; - - if (!a) - return true; + LIST_FOREACH(items, aa, a) { + if (!bb) + return false; - if (a->length != b->length) - return false; + if (memcmp_nn(aa->data, aa->length, bb->data, bb->length) != 0) + return false; - if (memcmp(a->data, b->data, a->length) != 0) - return false; + bb = bb->items_next; + } - return dns_txt_item_equal(a->items_next, b->items_next); + return !bb; } DnsTxtItem *dns_txt_item_copy(DnsTxtItem *first) {