X-Git-Url: https://git.decadent.org.uk/gitweb/?a=blobdiff_plain;f=utils%2Fstatd%2Fcallback.c;h=d5d036e9fc28357b3ef703f3da3005f7cee0ad06;hb=4b2f63a5e581ecfa12abb2419310c4e62eb27134;hp=c9c686d4f1c437c346c3652836981255fee88397;hpb=c7f54cc9a23167dea6bdc3e93834d070efa7e7e7;p=nfs-utils.git diff --git a/utils/statd/callback.c b/utils/statd/callback.c index c9c686d..d5d036e 100644 --- a/utils/statd/callback.c +++ b/utils/statd/callback.c @@ -6,9 +6,13 @@ * NSM for Linux. */ -#include "config.h" +#ifdef HAVE_CONFIG_H +#include +#endif +#include "misc.h" #include "statd.h" #include "notlist.h" +#include /* Callback notify list. */ /* notify_list *cbnl = NULL; ... never used */ @@ -25,15 +29,17 @@ sm_notify_1_svc(struct stat_chge *argp, struct svc_req *rqstp) { notify_list *lp, *call; static char *result = NULL; + char *ip_addr = xstrdup(inet_ntoa(svc_getcaller(rqstp->rq_xprt) + ->sin_addr)); - dprintf(L_DEBUG, "Received SM_NOTIFY from %s, state: %d", + dprintf(N_DEBUG, "Received SM_NOTIFY from %s, state: %d", argp->mon_name, argp->state); /* quick check - don't bother if we're not monitoring anyone */ /* LH - this was != MULL, meaning that if anyone _was_ in our RTNL, * we'd never pass this point. */ if (!(lp = rtnl)) { - log(L_WARNING, "SM_NOTIFY from %s while not monitoring any hosts.", + note(N_WARNING, "SM_NOTIFY from %s while not monitoring any hosts.", argp->mon_name, argp->state); return ((void *) &result); } @@ -43,15 +49,15 @@ sm_notify_1_svc(struct stat_chge *argp, struct svc_req *rqstp) * it. Lockd will want to continue monitoring the remote host * until it issues an SM_UNMON call. */ - while ((lp = nlist_gethost(lp, argp->mon_name, 0)) != NULL) { - if (NL_STATE(lp) != argp->state) { + for (lp = rtnl ; lp ; lp = lp->next) + if (NL_STATE(lp) != argp->state && + (matchhostname(argp->mon_name, lp->dns_name) || + matchhostname(ip_addr, lp->dns_name))) { NL_STATE(lp) = argp->state; call = nlist_clone(lp); - NL_TYPE(call) = NOTIFY_CALLBACK; nlist_insert(¬ify, call); } - lp = NL_NEXT(lp); - } + return ((void *) &result); }