[PATCH] cifs-utils: smbinfo.c: probably harmless wrong memset sizes + printf format correction

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



The attached patch is my attempt at fixing two possibly harmless
complaints from "cppcheck --enable=warning" from the cifs-utils git
master branch version of smbinfo.c.

1. A printf format should have been "%u" instead of "%d" in print_quota.

2. An incorrect size was being passed to memset in thirteen nearly
identical places, each using "sizeof(qi)" when "sizeof(*qi)".  I am
not sure but I think these mistakes were probably harmless because the
memset calls might all be unnecessary and the sizes passed to each
memset call might never have been larger than it was supposed to be.

Because each of the effected memset calls was immediately preceded by
the malloc which allocated the data structure and because they each
ignored the possibility that malloc could fail, I made a function,
xmalloc0 to combine allocating the memory, zeroing it and exiting with
a non-zero exit value and a failure message on allocation failure
(which appears to be a fine way to handle the error in this program).
The function uses calloc, which could introduce an unnecessary
multiply, in the hopes that some calloc implementations may avoid the
memset in the case of freshly allocated memory from mmap, which would
probably be the case in this program, although I do not know if any
calloc implementations make this optimization.  Anyhow, at least this
way, the size of the data structure is only computed once in the
source code.

I realize that these memory allocations may all be for small data
structures that should be allocated on the stack and also may not need
to be cleared to all zeroes, but I did not want to delve into coding
style conventions for stack allocation in the CIFS source tree, and I
was not 100% certain that clearing the allocated memory was
unnecessary, although I do see other lines that explicitly initialize
some field in that that allocated memory to zero.  So, please feel
free to replace my changes with something better or one that involves
less code churn.

I should also warn that my only testing of these changes was to make
sure that "cppcheck --enable=warning" no longer complains, that the
file compiled without complaint (with cifs-utils standard "-Wall
-Wextra" arguments) and that "./smbinfo quote /dev/null" got past the
memory allocation to the (correct) ioctl error for /dev/null.

Also, I am not a CIFS developer and this may be the first time I have
submitted a patch, certainly the first time I remember, so please
forgive me and feel free to instruct me if I should be following some
different process to submit this patch.

Thanks in advance for considering this patch submission.

Adam
--- cifs-utils/smbinfo.c.orig	2019-05-25 14:19:56.758474588 -0700
+++ cifs-utils/smbinfo.c	2019-05-25 14:26:22.633256913 -0700
@@ -97,6 +97,18 @@ usage(char *name)
 	exit(1);
 }
 
+static void *
+xmalloc0(size_t nbytes)
+{
+	void *result = calloc(1, nbytes);
+	if (result == NULL) {
+		fprintf(stderr, "%s: failed to allocate %zu bytes.\n",
+			__func__, nbytes);
+		exit(1);
+	}
+	return result;
+}
+
 static void
 win_to_timeval(uint64_t smb2_time, struct timeval *tv)
 {
@@ -225,8 +237,7 @@ fsctlgetobjid(int f)
 
 	fstat(f, &st);
 
-	qi = malloc(sizeof(struct smb_query_info) + 64);
-	memset(qi, 0, sizeof(qi) + 64);
+	qi = xmalloc0(sizeof(struct smb_query_info) + 64);
 	qi->info_type = 0x9009c;
 	qi->file_info_class = 0;
 	qi->additional_information = 0;
@@ -268,8 +279,7 @@ fileaccessinfo(int f)
 
 	fstat(f, &st);
 
-	qi = malloc(sizeof(struct smb_query_info) + 4);
-	memset(qi, 0, sizeof(qi) + 4);
+	qi = xmalloc0(sizeof(struct smb_query_info) + 4);
 	qi->info_type = 0x01;
 	qi->file_info_class = 8;
 	qi->additional_information = 0;
@@ -322,8 +332,7 @@ filealigninfo(int f)
 {
 	struct smb_query_info *qi;
 
-	qi = malloc(sizeof(struct smb_query_info) + 4);
-	memset(qi, 0, sizeof(qi) + 4);
+	qi = xmalloc0(sizeof(struct smb_query_info) + 4);
 	qi->info_type = 0x01;
 	qi->file_info_class = 17;
 	qi->additional_information = 0;
@@ -392,8 +401,7 @@ filebasicinfo(int f)
 {
 	struct smb_query_info *qi;
 
-	qi = malloc(sizeof(struct smb_query_info) + 40);
-	memset(qi, 0, sizeof(qi) + 40);
+	qi = xmalloc0(sizeof(struct smb_query_info) + 40);
 	qi->info_type = 0x01;
 	qi->file_info_class = 4;
 	qi->additional_information = 0;
@@ -432,8 +440,7 @@ filestandardinfo(int f)
 {
 	struct smb_query_info *qi;
 
-	qi = malloc(sizeof(struct smb_query_info) + 24);
-	memset(qi, 0, sizeof(qi) + 24);
+	qi = xmalloc0(sizeof(struct smb_query_info) + 24);
 	qi->info_type = 0x01;
 	qi->file_info_class = 5;
 	qi->additional_information = 0;
@@ -462,8 +469,7 @@ fileinternalinfo(int f)
 {
 	struct smb_query_info *qi;
 
-	qi = malloc(sizeof(struct smb_query_info) + 8);
-	memset(qi, 0, sizeof(qi) + 8);
+	qi = xmalloc0(sizeof(struct smb_query_info) + 8);
 	qi->info_type = 0x01;
 	qi->file_info_class = 6;
 	qi->additional_information = 0;
@@ -505,8 +511,7 @@ filemodeinfo(int f)
 {
 	struct smb_query_info *qi;
 
-	qi = malloc(sizeof(struct smb_query_info) + 4);
-	memset(qi, 0, sizeof(qi) + 4);
+	qi = xmalloc0(sizeof(struct smb_query_info) + 4);
 	qi->info_type = 0x01;
 	qi->file_info_class = 16;
 	qi->additional_information = 0;
@@ -535,8 +540,7 @@ filepositioninfo(int f)
 {
 	struct smb_query_info *qi;
 
-	qi = malloc(sizeof(struct smb_query_info) + 8);
-	memset(qi, 0, sizeof(qi) + 8);
+	qi = xmalloc0(sizeof(struct smb_query_info) + 8);
 	qi->info_type = 0x01;
 	qi->file_info_class = 14;
 	qi->additional_information = 0;
@@ -565,8 +569,7 @@ fileeainfo(int f)
 {
 	struct smb_query_info *qi;
 
-	qi = malloc(sizeof(struct smb_query_info) + 4);
-	memset(qi, 0, sizeof(qi) + 4);
+	qi = xmalloc0(sizeof(struct smb_query_info) + 4);
 	qi->info_type = 0x01;
 	qi->file_info_class = 7;
 	qi->additional_information = 0;
@@ -610,8 +613,7 @@ filefsfullsizeinfo(int f)
 {
 	struct smb_query_info *qi;
 
-	qi = malloc(sizeof(struct smb_query_info) + 32);
-	memset(qi, 0, sizeof(qi) + 32);
+	qi = xmalloc0(sizeof(struct smb_query_info) + 32);
 	qi->info_type = 0x02;
 	qi->file_info_class = 7;
 	qi->additional_information = 0;
@@ -634,8 +636,7 @@ fileallinfo(int f)
 
 	fstat(f, &st);
 
-	qi = malloc(sizeof(struct smb_query_info) + INPUT_BUFFER_LENGTH);
-	memset(qi, 0, sizeof(qi) + INPUT_BUFFER_LENGTH);
+	qi = xmalloc0(sizeof(struct smb_query_info) + INPUT_BUFFER_LENGTH);
 	qi->info_type = 0x01;
 	qi->file_info_class = 18;
 	qi->additional_information = 0;
@@ -862,8 +863,7 @@ secdesc(int f)
 
 	fstat(f, &st);
 
-	qi = malloc(sizeof(struct smb_query_info) + INPUT_BUFFER_LENGTH);
-	memset(qi, 0, sizeof(qi) + INPUT_BUFFER_LENGTH);
+	qi = xmalloc0(sizeof(struct smb_query_info) + INPUT_BUFFER_LENGTH);
 	qi->info_type = 0x03;
 	qi->file_info_class = 0;
 	qi->additional_information = 0x00000007; /* Owner, Group, Dacl */
@@ -892,7 +892,7 @@ one_more:
 
 	memcpy(&u32, &sd[off + 4], 4);
 	u32 = le32toh(u32);
-	printf("SID Length %d\n", u32);
+	printf("SID Length %u\n", u32);
 
 	memcpy(&u64, &sd[off + 8], 8);
 	win_to_timeval(le64toh(u64), &tv);
@@ -941,8 +941,7 @@ quota(int f)
 	char *buf;
 	int i;
 
-	qi = malloc(sizeof(struct smb_query_info) + INPUT_BUFFER_LENGTH);
-	memset(qi, 0, sizeof(struct smb_query_info) + INPUT_BUFFER_LENGTH);
+	qi = xmalloc0(sizeof(struct smb_query_info) + INPUT_BUFFER_LENGTH);
 	qi->info_type = 0x04;
 	qi->file_info_class = 0;
 	qi->additional_information = 0; /* Owner, Group, Dacl */

[Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux