summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--usr.sbin/afs/src/appl/fs/fs_copyacl.c6
-rw-r--r--usr.sbin/afs/src/arlad/dynroot.c2
-rw-r--r--usr.sbin/afs/src/arlad/fcache.c6
-rw-r--r--usr.sbin/afs/src/milko/lib/vld/common.c10
-rw-r--r--usr.sbin/afs/src/milko/lib/voldb/vol.c4
-rw-r--r--usr.sbin/afs/src/util/log.c8
6 files changed, 20 insertions, 16 deletions
diff --git a/usr.sbin/afs/src/appl/fs/fs_copyacl.c b/usr.sbin/afs/src/appl/fs/fs_copyacl.c
index 2a37040a1a9..236a924c756 100644
--- a/usr.sbin/afs/src/appl/fs/fs_copyacl.c
+++ b/usr.sbin/afs/src/appl/fs/fs_copyacl.c
@@ -51,7 +51,7 @@ afs_copyacl(char *fromdir, char *todir)
acl->NumPositiveEntries,
acl->NumNegativeEntries);
len = l;
- if (len >= sizeof(acltext)) {
+ if (len == -1 || len >= sizeof(acltext)) {
fserr(PROGNAME, ERANGE, todir);
return;
}
@@ -60,7 +60,7 @@ afs_copyacl(char *fromdir, char *todir)
l = snprintf(acltext + len, sizeof(acltext) - len,
"%s %d\n", position->name, position->RightsMask);
len += l;
- if (len >= sizeof(acltext)) {
+ if (l == -1 || len >= sizeof(acltext)) {
fserr(PROGNAME, ERANGE, todir);
return;
}
@@ -71,7 +71,7 @@ afs_copyacl(char *fromdir, char *todir)
l = snprintf(acltext + len, sizeof(acltext) - len,
"%s %d\n", position->name, position->RightsMask);
len += l;
- if (len >= sizeof(acltext)) {
+ if (l == -1 || len >= sizeof(acltext)) {
fserr(PROGNAME, ERANGE, todir);
return;
}
diff --git a/usr.sbin/afs/src/arlad/dynroot.c b/usr.sbin/afs/src/arlad/dynroot.c
index 49fec78e70b..2a67a51278e 100644
--- a/usr.sbin/afs/src/arlad/dynroot.c
+++ b/usr.sbin/afs/src/arlad/dynroot.c
@@ -188,7 +188,7 @@ dynroot_create_symlink (fbuf *fbuf, int32_t vnode)
len = snprintf (name, sizeof(name), "%c%s:root.cell.",
rw ? '%' : '#', cell->name);
- assert (len > 0 && len <= sizeof (name));
+ assert (len > 0 && len < sizeof (name));
ret = fbuf_truncate (fbuf, len);
if (ret)
diff --git a/usr.sbin/afs/src/arlad/fcache.c b/usr.sbin/afs/src/arlad/fcache.c
index b559ee1b2dd..c089d5f0b89 100644
--- a/usr.sbin/afs/src/arlad/fcache.c
+++ b/usr.sbin/afs/src/arlad/fcache.c
@@ -508,10 +508,10 @@ fcache_fhget (char *filename, fcache_cache_handle *handle)
GetCurrentDirectory(1024, buf);
- /* XXX CACHEHANDLESIZE */
- ret = snprintf ((char *)handle, 80, "%s\\%02X\\%02X", buf, a, b);
+ ret = snprintf ((char *)handle, CACHEHANDLESIZE,
+ "%s\\%02X\\%02X", buf, a, b);
- if (ret > 0)
+ if (ret > 0 && ret < CACHEHANDLESIZE)
handle->valid = 1;
return ret;
diff --git a/usr.sbin/afs/src/milko/lib/vld/common.c b/usr.sbin/afs/src/milko/lib/vld/common.c
index 5ded95a2851..58fadadc548 100644
--- a/usr.sbin/afs/src/milko/lib/vld/common.c
+++ b/usr.sbin/afs/src/milko/lib/vld/common.c
@@ -156,7 +156,7 @@ local_create_name (struct dp_part *dp, int32_t num, char *name, size_t sz)
(unsigned int) (num >> 8) & 0xff,
(unsigned int) num & 0xff);
- if (i >= sz)
+ if (i == -1 || i >= sz)
return(-1);
return 0;
}
@@ -172,7 +172,7 @@ local_create_file (struct dp_part *dp, onode_opaque *o,
i = snprintf(nodename, sizeof(nodename), "%s/inodeXXXXXXXXXX",
DP_NAME(dp));
- if (i > sizeof(nodename))
+ if (i == -1 || i >= sizeof(nodename))
return(ENOMEM);
fd = mkstemp(nodename);
@@ -198,7 +198,7 @@ local_create_file (struct dp_part *dp, onode_opaque *o,
i = snprintf(name, sizeof(name), "%s/%02x", DP_NAME(dp),
(unsigned int) (sb.st_ino >> 24) & 0xff);
- if (i > sizeof(name)) {
+ if (i == -1 || i >= sizeof(name)) {
ret = ENOMEM
goto bad;
}
@@ -206,7 +206,7 @@ local_create_file (struct dp_part *dp, onode_opaque *o,
i = snprintf(name, sizeof(name), "%s/%02x/%02x", DP_NAME(dp),
(unsigned int) (sb.st_ino >> 24) & 0xff,
(unsigned int) (sb.st_ino >> 16) & 0xff);
- if (i > sizeof(name)) {
+ if (i == -1 || i >= sizeof(name)) {
ret = ENOMEM
goto bad;
}
@@ -216,7 +216,7 @@ local_create_file (struct dp_part *dp, onode_opaque *o,
(unsigned int) (sb.st_ino >> 24) & 0xff,
(unsigned int) (sb.st_ino >> 16) & 0xff,
(unsigned int) (sb.st_ino >> 8) & 0xff);
- if (i > sizeof(name)) {
+ if (i == -1 || i >= sizeof(name)) {
ret = ENOMEM
goto bad;
}
diff --git a/usr.sbin/afs/src/milko/lib/voldb/vol.c b/usr.sbin/afs/src/milko/lib/voldb/vol.c
index acb51ad96fc..70ef4f2a283 100644
--- a/usr.sbin/afs/src/milko/lib/voldb/vol.c
+++ b/usr.sbin/afs/src/milko/lib/voldb/vol.c
@@ -50,7 +50,7 @@ vol_getname (uint32_t num, char *str, size_t sz)
{
int i;
i = snprintf (str, sz, "vol%08u", num);
- assert (i > 0);
+ assert (i > 0 && i < sz);
return 0;
}
@@ -83,7 +83,7 @@ vol_getfullname (uint32_t part, uint32_t num, char *str, size_t sz)
else
return EINVAL; /* XXX */
- assert (ret > 0);
+ assert (ret > 0 && ret < siz);
return 0;
}
diff --git a/usr.sbin/afs/src/util/log.c b/usr.sbin/afs/src/util/log.c
index 6e8240fc56f..aa369fd7f4c 100644
--- a/usr.sbin/afs/src/util/log.c
+++ b/usr.sbin/afs/src/util/log.c
@@ -735,7 +735,9 @@ _print_unit (Log_unit *unit, char *buf, size_t sz)
if (sz <= 0)
return(0);
ret = snprintf (buf, sz, "%s:", unit->name);
- if (ret == -1 || ret >= sz)
+ if (ret == -1)
+ ret = 0;
+ if (ret >= sz)
ret = sz - 1;
UPDATESZ(buf,sz,ret);
ret = unparse_flags (log_get_mask (unit), unit->unit, buf, sz);
@@ -758,7 +760,9 @@ log_mask2str (Log_method *method, Log_unit *unit, char *buf, size_t sz)
if (log_get_mask (method->units[i])) {
if (printed && sz > 0) {
ret = snprintf (buf, sz, ";");
- if (ret == -1 || ret >= sz)
+ if (ret == -1)
+ ret = 0;
+ if (ret >= sz)
ret = sz - 1;
UPDATESZ(buf,sz,ret);
}