diff options
author | Lennart Poettering <lennart@poettering.net> | 2017-02-13 20:44:11 +0100 |
---|---|---|
committer | Lennart Poettering <lennart@poettering.net> | 2017-02-13 20:44:11 +0100 |
commit | 1a63fc5430d66ccd72b0dbe3f6709724a811df40 (patch) | |
tree | 425434c200abc98c8764f30eb35140ed2b810d2e /src/resolve/resolved-dns-scope.c | |
parent | bceaa99d49538fc24151abed9f9d40c950f626a2 (diff) |
resolved: let's propagate errors from dns_scope_announce() and elsewhere
We don't actually make use of the return value for now, but it matches
our coding style elsewhere, and it actually shortens our code quite a
bit.
Also, add a missing OOM check after dns_answer_new().
Diffstat (limited to 'src/resolve/resolved-dns-scope.c')
-rw-r--r-- | src/resolve/resolved-dns-scope.c | 43 |
1 files changed, 21 insertions, 22 deletions
diff --git a/src/resolve/resolved-dns-scope.c b/src/resolve/resolved-dns-scope.c index 7a26edbaf7..cf098b3b03 100644 --- a/src/resolve/resolved-dns-scope.c +++ b/src/resolve/resolved-dns-scope.c @@ -1061,49 +1061,46 @@ static int on_announcement_timeout(sd_event_source *s, usec_t usec, void *userda scope->announce_event_source = sd_event_source_unref(scope->announce_event_source); - dns_scope_announce(scope, false); + (void) dns_scope_announce(scope, false); return 0; } -void dns_scope_announce(DnsScope *scope, bool goodbye) { +int dns_scope_announce(DnsScope *scope, bool goodbye) { _cleanup_(dns_answer_unrefp) DnsAnswer *answer = NULL; _cleanup_(dns_packet_unrefp) DnsPacket *p = NULL; LinkAddress *a; int r; if (!scope) - return; + return 0; if (scope->protocol != DNS_PROTOCOL_MDNS) - return; + return 0; answer = dns_answer_new(4); + if (!answer) + return log_oom(); + LIST_FOREACH(addresses, a, scope->link->addresses) { r = dns_answer_add(answer, a->mdns_address_rr, 0, goodbye ? DNS_ANSWER_GOODBYE : DNS_ANSWER_CACHE_FLUSH); - if (r < 0) { - log_debug_errno(r, "Failed to add address RR to answer: %m"); - return; - } + if (r < 0) + return log_debug_errno(r, "Failed to add address RR to answer: %m"); + r = dns_answer_add(answer, a->mdns_ptr_rr, 0, goodbye ? DNS_ANSWER_GOODBYE : DNS_ANSWER_CACHE_FLUSH); - if (r < 0) { - log_debug_errno(r, "Failed to add PTR RR to answer: %m"); - return; - } + if (r < 0) + return log_debug_errno(r, "Failed to add PTR RR to answer: %m"); } if (dns_answer_isempty(answer)) - return; + return 0; r = dns_scope_make_reply_packet(scope, 0, DNS_RCODE_SUCCESS, NULL, answer, NULL, false, &p); - if (r < 0) { - log_debug_errno(r, "Failed to build reply packet: %m"); - return; - } + if (r < 0) + return log_debug_errno(r, "Failed to build reply packet: %m"); + r = dns_scope_emit_udp(scope, -1, p); - if (r < 0) { - log_debug_errno(r, "Failed to send reply packet: %m"); - return; - } + if (r < 0) + return log_debug_errno(r, "Failed to send reply packet: %m"); /* In section 8.3 of RFC6762: "The Multicast DNS responder MUST send at least two unsolicited * responses, one second apart." */ @@ -1123,6 +1120,8 @@ void dns_scope_announce(DnsScope *scope, bool goodbye) { MDNS_JITTER_RANGE_USEC, on_announcement_timeout, scope); if (r < 0) - log_debug_errno(r, "Failed to schedule second announcement: %m"); + return log_debug_errno(r, "Failed to schedule second announcement: %m"); } + + return 0; } |