X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=elogind.git;a=blobdiff_plain;f=src%2Fresolve%2Fresolved-manager.c;h=fed9a7797359020bb2c30d62289a7a494f257637;hp=5fbb500fd0530dd57c2ab73a79c9d15b02a0cf0e;hb=e1c959948c0e31d6997bcdfbabfbd077784b2bae;hpb=76f468c8ea568fce98fa75d7f1d540256eb0940a diff --git a/src/resolve/resolved-manager.c b/src/resolve/resolved-manager.c index 5fbb500fd..fed9a7797 100644 --- a/src/resolve/resolved-manager.c +++ b/src/resolve/resolved-manager.c @@ -878,3 +878,23 @@ void manager_next_dns_server(Manager *m) { m->current_dns_server = m->dns_servers; } + +uint32_t manager_find_mtu(Manager *m) { + uint32_t mtu = 0; + Link *l; + Iterator i; + + /* If we don't know on which link a DNS packet would be + * delivered, let's find the largest MTU that works on all + * interfaces we know of */ + + HASHMAP_FOREACH(l, m->links, i) { + if (l->mtu <= 0) + continue; + + if (mtu <= 0 || l->mtu < mtu) + mtu = l->mtu; + } + + return mtu; +}