Blame SOURCES/0009-dmidecode-Add-helper-function-pr_comment.patch

dfabe0
From 2241f1dd232fe8e1d57fdb2482ad417ebe23279e Mon Sep 17 00:00:00 2001
dfabe0
From: Jean Delvare <jdelvare@suse.de>
dfabe0
Date: Wed, 1 Apr 2020 09:51:46 +0200
dfabe0
Subject: [PATCH 09/23] dmidecode: Add helper function pr_comment
dfabe0
dfabe0
Print all comments through a helper function pr_comment.
dfabe0
dfabe0
Signed-off-by: Jean Delvare <jdelvare@suse.de>
dfabe0
---
dfabe0
 Makefile    |  7 +++++--
dfabe0
 dmidecode.c | 33 +++++++++++++++++----------------
dfabe0
 dmioutput.c | 35 +++++++++++++++++++++++++++++++++++
dfabe0
 dmioutput.h | 22 ++++++++++++++++++++++
dfabe0
 4 files changed, 79 insertions(+), 18 deletions(-)
dfabe0
 create mode 100644 dmioutput.c
dfabe0
 create mode 100644 dmioutput.h
dfabe0
dfabe0
diff --git a/Makefile b/Makefile
dfabe0
index 77c931091b0f..5d58266ef2de 100644
dfabe0
--- a/Makefile
dfabe0
+++ b/Makefile
dfabe0
@@ -61,8 +61,8 @@ all : $(PROGRAMS)
dfabe0
 # Programs
dfabe0
 #
dfabe0
 
dfabe0
-dmidecode : dmidecode.o dmiopt.o dmioem.o util.o
dfabe0
-	$(CC) $(LDFLAGS) dmidecode.o dmiopt.o dmioem.o util.o -o $@
dfabe0
+dmidecode : dmidecode.o dmiopt.o dmioem.o dmioutput.o util.o
dfabe0
+	$(CC) $(LDFLAGS) dmidecode.o dmiopt.o dmioem.o dmioutput.o util.o -o $@
dfabe0
 
dfabe0
 biosdecode : biosdecode.o util.o
dfabe0
 	$(CC) $(LDFLAGS) biosdecode.o util.o -o $@
dfabe0
@@ -87,6 +87,9 @@ dmiopt.o : dmiopt.c config.h types.h util.h dmidecode.h dmiopt.h
dfabe0
 dmioem.o : dmioem.c types.h dmidecode.h dmioem.h
dfabe0
 	$(CC) $(CFLAGS) -c $< -o $@
dfabe0
 
dfabe0
+dmioutput.o : dmioutput.c types.h dmioutput.h
dfabe0
+	$(CC) $(CFLAGS) -c $< -o $@
dfabe0
+
dfabe0
 biosdecode.o : biosdecode.c version.h types.h util.h config.h 
dfabe0
 	$(CC) $(CFLAGS) -c $< -o $@
dfabe0
 
dfabe0
diff --git a/dmidecode.c b/dmidecode.c
dfabe0
index 8ec1d6b9597a..2939b2d307fc 100644
dfabe0
--- a/dmidecode.c
dfabe0
+++ b/dmidecode.c
dfabe0
@@ -80,6 +80,7 @@
dfabe0
 #include "dmidecode.h"
dfabe0
 #include "dmiopt.h"
dfabe0
 #include "dmioem.h"
dfabe0
+#include "dmioutput.h"
dfabe0
 
dfabe0
 #define out_of_spec "<OUT OF SPEC>"
dfabe0
 static const char *bad_index = "<BAD INDEX>";
dfabe0
@@ -5162,7 +5163,7 @@ static void dmi_table_string(const struct dmi_header *h, const u8 *data, u16 ver
dfabe0
 static void dmi_table_dump(const u8 *buf, u32 len)
dfabe0
 {
dfabe0
 	if (!(opt.flags & FLAG_QUIET))
dfabe0
-		printf("# Writing %d bytes to %s.\n", len, opt.dumpfile);
dfabe0
+		pr_comment("Writing %d bytes to %s.", len, opt.dumpfile);
dfabe0
 	write_dump(32, len, buf, opt.dumpfile, 0);
dfabe0
 }
dfabe0
 
dfabe0
@@ -5283,11 +5284,11 @@ static void dmi_table(off_t base, u32 len, u16 num, u32 ver, const char *devmem,
dfabe0
 
dfabe0
 	if (ver > SUPPORTED_SMBIOS_VER && !(opt.flags & FLAG_QUIET))
dfabe0
 	{
dfabe0
-		printf("# SMBIOS implementations newer than version %u.%u.%u are not\n"
dfabe0
-		       "# fully supported by this version of dmidecode.\n",
dfabe0
-		       SUPPORTED_SMBIOS_VER >> 16,
dfabe0
-		       (SUPPORTED_SMBIOS_VER >> 8) & 0xFF,
dfabe0
-		       SUPPORTED_SMBIOS_VER & 0xFF);
dfabe0
+		pr_comment("SMBIOS implementations newer than version %u.%u.%u are not",
dfabe0
+			   SUPPORTED_SMBIOS_VER >> 16,
dfabe0
+			   (SUPPORTED_SMBIOS_VER >> 8) & 0xFF,
dfabe0
+			   SUPPORTED_SMBIOS_VER & 0xFF);
dfabe0
+		pr_comment("fully supported by this version of dmidecode.");
dfabe0
 	}
dfabe0
 
dfabe0
 	if (!(opt.flags & FLAG_QUIET))
dfabe0
@@ -5417,8 +5418,8 @@ static int smbios3_decode(u8 *buf, const char *devmem, u32 flags)
dfabe0
 		overwrite_smbios3_address(crafted);
dfabe0
 
dfabe0
 		if (!(opt.flags & FLAG_QUIET))
dfabe0
-			printf("# Writing %d bytes to %s.\n", crafted[0x06],
dfabe0
-			       opt.dumpfile);
dfabe0
+			pr_comment("Writing %d bytes to %s.", crafted[0x06],
dfabe0
+				   opt.dumpfile);
dfabe0
 		write_dump(0, crafted[0x06], crafted, opt.dumpfile, 1);
dfabe0
 	}
dfabe0
 
dfabe0
@@ -5478,8 +5479,8 @@ static int smbios_decode(u8 *buf, const char *devmem, u32 flags)
dfabe0
 		overwrite_dmi_address(crafted + 0x10);
dfabe0
 
dfabe0
 		if (!(opt.flags & FLAG_QUIET))
dfabe0
-			printf("# Writing %d bytes to %s.\n", crafted[0x05],
dfabe0
-				opt.dumpfile);
dfabe0
+			pr_comment("Writing %d bytes to %s.", crafted[0x05],
dfabe0
+				   opt.dumpfile);
dfabe0
 		write_dump(0, crafted[0x05], crafted, opt.dumpfile, 1);
dfabe0
 	}
dfabe0
 
dfabe0
@@ -5507,8 +5508,8 @@ static int legacy_decode(u8 *buf, const char *devmem, u32 flags)
dfabe0
 		overwrite_dmi_address(crafted);
dfabe0
 
dfabe0
 		if (!(opt.flags & FLAG_QUIET))
dfabe0
-			printf("# Writing %d bytes to %s.\n", 0x0F,
dfabe0
-				opt.dumpfile);
dfabe0
+			pr_comment("Writing %d bytes to %s.", 0x0F,
dfabe0
+				   opt.dumpfile);
dfabe0
 		write_dump(0, 0x0F, crafted, opt.dumpfile, 1);
dfabe0
 	}
dfabe0
 
dfabe0
@@ -5586,8 +5587,8 @@ static int address_from_efi(off_t *address)
dfabe0
 #endif
dfabe0
 
dfabe0
 	if (ret == 0 && !(opt.flags & FLAG_QUIET))
dfabe0
-		printf("# %s entry point at 0x%08llx\n",
dfabe0
-		       eptype, (unsigned long long)*address);
dfabe0
+		pr_comment("%s entry point at 0x%08llx",
dfabe0
+			   eptype, (unsigned long long)*address);
dfabe0
 
dfabe0
 	return ret;
dfabe0
 }
dfabe0
@@ -5638,7 +5639,7 @@ int main(int argc, char * const argv[])
dfabe0
 	}
dfabe0
 
dfabe0
 	if (!(opt.flags & FLAG_QUIET))
dfabe0
-		printf("# dmidecode %s\n", VERSION);
dfabe0
+		pr_comment("dmidecode %s", VERSION);
dfabe0
 
dfabe0
 	/* Read from dump if so instructed */
dfabe0
 	if (opt.flags & FLAG_FROM_DUMP)
dfabe0
@@ -5783,7 +5784,7 @@ int main(int argc, char * const argv[])
dfabe0
 
dfabe0
 done:
dfabe0
 	if (!found && !(opt.flags & FLAG_QUIET))
dfabe0
-		printf("# No SMBIOS nor DMI entry point found, sorry.\n");
dfabe0
+		pr_comment("No SMBIOS nor DMI entry point found, sorry.");
dfabe0
 
dfabe0
 	free(buf);
dfabe0
 exit_free:
dfabe0
diff --git a/dmioutput.c b/dmioutput.c
dfabe0
new file mode 100644
dfabe0
index 000000000000..e762a035f39d
dfabe0
--- /dev/null
dfabe0
+++ b/dmioutput.c
dfabe0
@@ -0,0 +1,35 @@
dfabe0
+/*
dfabe0
+ * Generic output functions
dfabe0
+ * This file is part of the dmidecode project.
dfabe0
+ *
dfabe0
+ *   Copyright (C) 2020 Jean Delvare <jdelvare@suse.de>
dfabe0
+ *
dfabe0
+ *   This program is free software; you can redistribute it and/or modify
dfabe0
+ *   it under the terms of the GNU General Public License as published by
dfabe0
+ *   the Free Software Foundation; either version 2 of the License, or
dfabe0
+ *   (at your option) any later version.
dfabe0
+ *
dfabe0
+ *   This program is distributed in the hope that it will be useful,
dfabe0
+ *   but WITHOUT ANY WARRANTY; without even the implied warranty of
dfabe0
+ *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
dfabe0
+ *   GNU General Public License for more details.
dfabe0
+ *
dfabe0
+ *   You should have received a copy of the GNU General Public License
dfabe0
+ *   along with this program; if not, write to the Free Software
dfabe0
+ *   Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA
dfabe0
+ */
dfabe0
+
dfabe0
+#include <stdarg.h>
dfabe0
+#include <stdio.h>
dfabe0
+#include "dmioutput.h"
dfabe0
+
dfabe0
+void pr_comment(const char *format, ...)
dfabe0
+{
dfabe0
+	va_list args;
dfabe0
+
dfabe0
+	printf("# ");
dfabe0
+	va_start(args, format);
dfabe0
+	vprintf(format, args);
dfabe0
+	va_end(args);
dfabe0
+	printf("\n");
dfabe0
+}
dfabe0
diff --git a/dmioutput.h b/dmioutput.h
dfabe0
new file mode 100644
dfabe0
index 000000000000..b6cf5ee8b60e
dfabe0
--- /dev/null
dfabe0
+++ b/dmioutput.h
dfabe0
@@ -0,0 +1,22 @@
dfabe0
+/*
dfabe0
+ * Generic output functions
dfabe0
+ * This file is part of the dmidecode project.
dfabe0
+ *
dfabe0
+ *   Copyright (C) 2020 Jean Delvare <jdelvare@suse.de>
dfabe0
+ *
dfabe0
+ *   This program is free software; you can redistribute it and/or modify
dfabe0
+ *   it under the terms of the GNU General Public License as published by
dfabe0
+ *   the Free Software Foundation; either version 2 of the License, or
dfabe0
+ *   (at your option) any later version.
dfabe0
+ *
dfabe0
+ *   This program is distributed in the hope that it will be useful,
dfabe0
+ *   but WITHOUT ANY WARRANTY; without even the implied warranty of
dfabe0
+ *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
dfabe0
+ *   GNU General Public License for more details.
dfabe0
+ *
dfabe0
+ *   You should have received a copy of the GNU General Public License
dfabe0
+ *   along with this program; if not, write to the Free Software
dfabe0
+ *   Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA
dfabe0
+ */
dfabe0
+
dfabe0
+void pr_comment(const char *format, ...);
dfabe0
-- 
dfabe0
2.17.1
dfabe0