X-Git-Url: https://git.decadent.org.uk/gitweb/?p=nfs-utils.git;a=blobdiff_plain;f=utils%2Fmountd%2Fcache.c;h=c264e142803dedbbcfa67aaf42a05e72b60acdc3;hp=64ca5ba3fee1d561ad1cf0042585cea82dbf937a;hb=768ab6039b53d767158c50bcc5fceb2ec2516a8a;hpb=d8b5dc74c5aa258a937b3b3d74366f997ffd6d7f diff --git a/utils/mountd/cache.c b/utils/mountd/cache.c index 64ca5ba..c264e14 100644 --- a/utils/mountd/cache.c +++ b/utils/mountd/cache.c @@ -29,7 +29,6 @@ #include "nfslib.h" #include "exportfs.h" #include "mountd.h" -#include "xmalloc.h" #include "fsloc.h" #include "pseudoflavors.h" @@ -109,12 +108,10 @@ static void auth_unix_ip(FILE *f) struct addrinfo *ai = NULL; ai = client_resolve(tmp->ai_addr); - if (ai == NULL) - goto out; - client = client_compose(ai); - freeaddrinfo(ai); - if (!client) - goto out; + if (ai) { + client = client_compose(ai); + freeaddrinfo(ai); + } } qword_print(f, "nfsd"); qword_print(f, ipaddr); @@ -127,7 +124,6 @@ static void auth_unix_ip(FILE *f) xlog(D_CALL, "auth_unix_ip: client %p '%s'", client, client?client: "DEFAULT"); free(client); -out: freeaddrinfo(tmp); } @@ -248,7 +244,7 @@ static int get_uuid(const char *val, size_t uuidlen, char *u) memset(u, 0, uuidlen); for ( ; *val ; val++) { - char c = *val; + int c = *val; if (!isxdigit(c)) continue; if (isalpha(c)) { @@ -260,7 +256,7 @@ static int get_uuid(const char *val, size_t uuidlen, char *u) c = c - '0' + 0; if ((i&1) == 0) c <<= 4; - u[i/2] ^= c; + u[i/2] ^= (char)c; i++; if (i == uuidlen*2) i = 0; @@ -758,7 +754,7 @@ static int dump_to_cache(FILE *f, char *domain, char *path, struct exportent *ex static int is_subdirectory(char *child, char *parent) { - int l = strlen(parent); + size_t l = strlen(parent); return strcmp(child, parent) == 0 || (strncmp(child, parent, l) == 0 && child[l] == '/');