Blame SOURCES/sendmail-8.16.0.29-fix-covscan-issues.patch

06f80e
diff --git a/include/sm/varargs.h b/include/sm/varargs.h
06f80e
index 612858d..2609630 100644
06f80e
--- a/include/sm/varargs.h
06f80e
+++ b/include/sm/varargs.h
06f80e
@@ -32,6 +32,11 @@
06f80e
 #  define SM_VA_COPY(dst, src)	__va_copy((dst), (src))
06f80e
 # else
06f80e
 #  define SM_VA_COPY(dst, src)	memcpy(&(dst), &(src), sizeof((dst)))
06f80e
+#  define SM_VA_END_COPY(ap)	do { } while (0)
06f80e
+# endif
06f80e
+
06f80e
+# ifndef SM_VA_END_COPY
06f80e
+#  define SM_VA_END_COPY(ap)	va_end(ap)
06f80e
 # endif
06f80e
 
06f80e
 /*
06f80e
diff --git a/libsm/vfprintf.c b/libsm/vfprintf.c
06f80e
index 87c353c..c99d4e5 100644
06f80e
--- a/libsm/vfprintf.c
06f80e
+++ b/libsm/vfprintf.c
06f80e
@@ -782,6 +782,7 @@ number:			if ((dprec = prec) >= 0)
06f80e
 done:
06f80e
 	FLUSH();
06f80e
 error:
06f80e
+	SM_VA_END_COPY(orgap);
06f80e
 	if ((argtable != NULL) && (argtable != statargtable))
06f80e
 		sm_free(argtable);
06f80e
 	return sm_error(fp) ? SM_IO_EOF : ret;
06f80e
diff --git a/sendmail/milter.c b/sendmail/milter.c
06f80e
index 462efd2..af6dc66 100644
06f80e
--- a/sendmail/milter.c
06f80e
+++ b/sendmail/milter.c
06f80e
@@ -2437,8 +2437,7 @@ milter_negotiate(m, e, milters)
06f80e
 			sm_syslog(LOG_ERR, e->e_id,
06f80e
 				  "Milter (%s): negotiate: returned %c instead of %c",
06f80e
 				  m->mf_name, rcmd, SMFIC_OPTNEG);
06f80e
-		if (response != NULL)
06f80e
-			sm_free(response); /* XXX */
06f80e
+		SM_FREE(response);
06f80e
 		milter_error(m, e);
06f80e
 		return -1;
06f80e
 	}
06f80e
@@ -2453,8 +2452,7 @@ milter_negotiate(m, e, milters)
06f80e
 			sm_syslog(LOG_ERR, e->e_id,
06f80e
 				  "Milter (%s): negotiate: did not return valid info",
06f80e
 				  m->mf_name);
06f80e
-		if (response != NULL)
06f80e
-			sm_free(response); /* XXX */
06f80e
+		SM_FREE(response);
06f80e
 		milter_error(m, e);
06f80e
 		return -1;
06f80e
 	}
06f80e
@@ -2472,8 +2470,7 @@ milter_negotiate(m, e, milters)
06f80e
 			sm_syslog(LOG_ERR, e->e_id,
06f80e
 				  "Milter (%s): negotiate: did not return enough info",
06f80e
 				  m->mf_name);
06f80e
-		if (response != NULL)
06f80e
-			sm_free(response); /* XXX */
06f80e
+		SM_FREE(response);
06f80e
 		milter_error(m, e);
06f80e
 		return -1;
06f80e
 	}
06f80e
@@ -2589,11 +2586,11 @@ milter_negotiate(m, e, milters)
06f80e
 	if (tTd(64, 5))
06f80e
 		sm_dprintf("milter_negotiate(%s): received: version %u, fflags 0x%x, pflags 0x%x\n",
06f80e
 			m->mf_name, m->mf_fvers, m->mf_fflags, m->mf_pflags);
06f80e
+	SM_FREE(response);
06f80e
 	return 0;
06f80e
 
06f80e
   error:
06f80e
-	if (response != NULL)
06f80e
-		sm_free(response); /* XXX */
06f80e
+	SM_FREE(response);
06f80e
 	return -1;
06f80e
 }
06f80e
 
06f80e
@@ -3230,6 +3227,7 @@ milter_changeheader(m, response, rlen, e)
06f80e
 			addheader(newstr(field), mh_value, H_USER, e,
06f80e
 				!bitset(SMFIP_HDR_LEADSPC, m->mf_pflags));
06f80e
 		}
06f80e
+		SM_FREE(mh_value);
06f80e
 		return;
06f80e
 	}
06f80e
 
06f80e
@@ -3438,6 +3436,8 @@ milter_chgfrom(response, rlen, e)
06f80e
 	{
06f80e
 		if (tTd(64, 10))
06f80e
 			sm_dprintf("didn't follow protocol argc=%d\n", argc);
06f80e
+		if (argv != NULL)
06f80e
+			free(argv);
06f80e
 		return;
06f80e
 	}
06f80e
 
06f80e
@@ -3456,6 +3456,7 @@ milter_chgfrom(response, rlen, e)
06f80e
 				mail_esmtp_args);
06f80e
 	}
06f80e
 	Errors = olderrors;
06f80e
+	free(argv);
06f80e
 	return;
06f80e
 }
06f80e
 
06f80e
@@ -3503,6 +3504,8 @@ milter_addrcpt_par(response, rlen, e)
06f80e
 	{
06f80e
 		if (tTd(64, 10))
06f80e
 			sm_dprintf("didn't follow protocol argc=%d\n", argc);
06f80e
+		if (argv != NULL)
06f80e
+			free(argv);
06f80e
 		return;
06f80e
 	}
06f80e
 	olderrors = Errors;
06f80e
@@ -3527,6 +3530,7 @@ milter_addrcpt_par(response, rlen, e)
06f80e
 	}
06f80e
 
06f80e
 	Errors = olderrors;
06f80e
+	free(argv);
06f80e
 	return;
06f80e
 }
06f80e
 
06f80e
diff --git a/sendmail/queue.c b/sendmail/queue.c
06f80e
index 503f296..c9153c8 100644
06f80e
--- a/sendmail/queue.c
06f80e
+++ b/sendmail/queue.c
06f80e
@@ -8590,6 +8590,7 @@ split_by_recipient(e)
06f80e
 		if (split_within_queue(ee) == SM_SPLIT_FAIL)
06f80e
 		{
06f80e
 			e->e_sibling = firstsibling;
06f80e
+			SM_FREE(lsplits);
06f80e
 			return false;
06f80e
 		}
06f80e
 		ee->e_flags |= EF_SPLIT;
06f80e
@@ -8604,8 +8605,7 @@ split_by_recipient(e)
06f80e
 				if (p == NULL)
06f80e
 				{
06f80e
 					/* let's try to get this done */
06f80e
-					sm_free(lsplits);
06f80e
-					lsplits = NULL;
06f80e
+					SM_FREE(lsplits);
06f80e
 				}
06f80e
 				else
06f80e
 					lsplits = p;
06f80e
@@ -8627,7 +8627,7 @@ split_by_recipient(e)
06f80e
 	{
06f80e
 		sm_syslog(LOG_NOTICE, e->e_id, "split: count=%d, id%s=%s",
06f80e
 			  n - 1, n > 2 ? "s" : "", lsplits);
06f80e
-		sm_free(lsplits);
06f80e
+		SM_FREE(lsplits);
06f80e
 	}
06f80e
 	split = split_within_queue(e) != SM_SPLIT_FAIL;
06f80e
 	if (split)