|
|
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 |
|