Blame SOURCES/0013-dmidecode-Add-helper-function-pr_handle_name.patch

fc71ac
From ebbe1dbe9a4413232949d97a506db6a7c00865fa Mon Sep 17 00:00:00 2001
fc71ac
From: Jean Delvare <jdelvare@suse.de>
fc71ac
Date: Wed, 1 Apr 2020 09:52:00 +0200
fc71ac
Subject: [PATCH 13/23] dmidecode: Add helper function pr_handle_name
fc71ac
fc71ac
Print the name of each handle type through a helper function
fc71ac
pr_handle_name.
fc71ac
fc71ac
Signed-off-by: Jean Delvare <jdelvare@suse.de>
fc71ac
---
fc71ac
 dmidecode.c | 99 ++++++++++++++++++++++++++---------------------------
fc71ac
 dmioem.c    | 25 +++++++-------
fc71ac
 dmioutput.c | 10 ++++++
fc71ac
 dmioutput.h |  1 +
fc71ac
 4 files changed, 73 insertions(+), 62 deletions(-)
fc71ac
fc71ac
diff --git a/dmidecode.c b/dmidecode.c
fc71ac
index 8ba8d078614e..c226bad06638 100644
fc71ac
--- a/dmidecode.c
fc71ac
+++ b/dmidecode.c
fc71ac
@@ -2083,11 +2083,10 @@ static void dmi_on_board_devices(const struct dmi_header *h, const char *prefix)
fc71ac
 	for (i = 0; i < count; i++)
fc71ac
 	{
fc71ac
 		if (count == 1)
fc71ac
-			printf("%sOn Board Device Information\n",
fc71ac
-				prefix);
fc71ac
+			pr_handle_name("On Board Device Information");
fc71ac
 		else
fc71ac
-			printf("%sOn Board Device %d Information\n",
fc71ac
-				prefix, i + 1);
fc71ac
+			pr_handle_name("On Board Device %d Information",
fc71ac
+				       i + 1);
fc71ac
 		printf("%s\tType: %s\n",
fc71ac
 			prefix, dmi_on_board_devices_type(p[2 * i] & 0x7F));
fc71ac
 		printf("%s\tStatus: %s\n",
fc71ac
@@ -3397,7 +3396,7 @@ static void dmi_additional_info(const struct dmi_header *h, const char *prefix)
fc71ac
 
fc71ac
 	for (i = 0; i < count; i++)
fc71ac
 	{
fc71ac
-		printf("%sAdditional Information %d\n", prefix, i + 1);
fc71ac
+		pr_handle_name("Additional Information %d", i + 1);
fc71ac
 
fc71ac
 		/* Check for short entries */
fc71ac
 		if (h->length < offset + 1) break;
fc71ac
@@ -3893,7 +3892,7 @@ static void dmi_decode(const struct dmi_header *h, u16 ver)
fc71ac
 	switch (h->type)
fc71ac
 	{
fc71ac
 		case 0: /* 7.1 BIOS Information */
fc71ac
-			printf("BIOS Information\n");
fc71ac
+			pr_handle_name("BIOS Information");
fc71ac
 			if (h->length < 0x12) break;
fc71ac
 			printf("\tVendor: %s\n",
fc71ac
 				dmi_string(h, data[0x04]));
fc71ac
@@ -3933,7 +3932,7 @@ static void dmi_decode(const struct dmi_header *h, u16 ver)
fc71ac
 			break;
fc71ac
 
fc71ac
 		case 1: /* 7.2 System Information */
fc71ac
-			printf("System Information\n");
fc71ac
+			pr_handle_name("System Information");
fc71ac
 			if (h->length < 0x08) break;
fc71ac
 			printf("\tManufacturer: %s\n",
fc71ac
 				dmi_string(h, data[0x04]));
fc71ac
@@ -3957,7 +3956,7 @@ static void dmi_decode(const struct dmi_header *h, u16 ver)
fc71ac
 			break;
fc71ac
 
fc71ac
 		case 2: /* 7.3 Base Board Information */
fc71ac
-			printf("Base Board Information\n");
fc71ac
+			pr_handle_name("Base Board Information");
fc71ac
 			if (h->length < 0x08) break;
fc71ac
 			printf("\tManufacturer: %s\n",
fc71ac
 				dmi_string(h, data[0x04]));
fc71ac
@@ -3988,7 +3987,7 @@ static void dmi_decode(const struct dmi_header *h, u16 ver)
fc71ac
 			break;
fc71ac
 
fc71ac
 		case 3: /* 7.4 Chassis Information */
fc71ac
-			printf("Chassis Information\n");
fc71ac
+			pr_handle_name("Chassis Information");
fc71ac
 			if (h->length < 0x09) break;
fc71ac
 			printf("\tManufacturer: %s\n",
fc71ac
 				dmi_string(h, data[0x04]));
fc71ac
@@ -4030,7 +4029,7 @@ static void dmi_decode(const struct dmi_header *h, u16 ver)
fc71ac
 			break;
fc71ac
 
fc71ac
 		case 4: /* 7.5 Processor Information */
fc71ac
-			printf("Processor Information\n");
fc71ac
+			pr_handle_name("Processor Information");
fc71ac
 			if (h->length < 0x1A) break;
fc71ac
 			printf("\tSocket Designation: %s\n",
fc71ac
 				dmi_string(h, data[0x04]));
fc71ac
@@ -4100,7 +4099,7 @@ static void dmi_decode(const struct dmi_header *h, u16 ver)
fc71ac
 			break;
fc71ac
 
fc71ac
 		case 5: /* 7.6 Memory Controller Information */
fc71ac
-			printf("Memory Controller Information\n");
fc71ac
+			pr_handle_name("Memory Controller Information");
fc71ac
 			if (h->length < 0x0F) break;
fc71ac
 			printf("\tError Detecting Method: %s\n",
fc71ac
 				dmi_memory_controller_ed_method(data[0x04]));
fc71ac
@@ -4130,7 +4129,7 @@ static void dmi_decode(const struct dmi_header *h, u16 ver)
fc71ac
 			break;
fc71ac
 
fc71ac
 		case 6: /* 7.7 Memory Module Information */
fc71ac
-			printf("Memory Module Information\n");
fc71ac
+			pr_handle_name("Memory Module Information");
fc71ac
 			if (h->length < 0x0C) break;
fc71ac
 			printf("\tSocket Designation: %s\n",
fc71ac
 				dmi_string(h, data[0x04]));
fc71ac
@@ -4154,7 +4153,7 @@ static void dmi_decode(const struct dmi_header *h, u16 ver)
fc71ac
 			break;
fc71ac
 
fc71ac
 		case 7: /* 7.8 Cache Information */
fc71ac
-			printf("Cache Information\n");
fc71ac
+			pr_handle_name("Cache Information");
fc71ac
 			if (h->length < 0x0F) break;
fc71ac
 			printf("\tSocket Designation: %s\n",
fc71ac
 				dmi_string(h, data[0x04]));
fc71ac
@@ -4197,7 +4196,7 @@ static void dmi_decode(const struct dmi_header *h, u16 ver)
fc71ac
 			break;
fc71ac
 
fc71ac
 		case 8: /* 7.9 Port Connector Information */
fc71ac
-			printf("Port Connector Information\n");
fc71ac
+			pr_handle_name("Port Connector Information");
fc71ac
 			if (h->length < 0x09) break;
fc71ac
 			printf("\tInternal Reference Designator: %s\n",
fc71ac
 				dmi_string(h, data[0x04]));
fc71ac
@@ -4212,7 +4211,7 @@ static void dmi_decode(const struct dmi_header *h, u16 ver)
fc71ac
 			break;
fc71ac
 
fc71ac
 		case 9: /* 7.10 System Slots */
fc71ac
-			printf("System Slot Information\n");
fc71ac
+			pr_handle_name("System Slot Information");
fc71ac
 			if (h->length < 0x0C) break;
fc71ac
 			printf("\tDesignation: %s\n",
fc71ac
 				dmi_string(h, data[0x04]));
fc71ac
@@ -4243,19 +4242,19 @@ static void dmi_decode(const struct dmi_header *h, u16 ver)
fc71ac
 			break;
fc71ac
 
fc71ac
 		case 11: /* 7.12 OEM Strings */
fc71ac
-			printf("OEM Strings\n");
fc71ac
+			pr_handle_name("OEM Strings");
fc71ac
 			if (h->length < 0x05) break;
fc71ac
 			dmi_oem_strings(h, "\t");
fc71ac
 			break;
fc71ac
 
fc71ac
 		case 12: /* 7.13 System Configuration Options */
fc71ac
-			printf("System Configuration Options\n");
fc71ac
+			pr_handle_name("System Configuration Options");
fc71ac
 			if (h->length < 0x05) break;
fc71ac
 			dmi_system_configuration_options(h, "\t");
fc71ac
 			break;
fc71ac
 
fc71ac
 		case 13: /* 7.14 BIOS Language Information */
fc71ac
-			printf("BIOS Language Information\n");
fc71ac
+			pr_handle_name("BIOS Language Information");
fc71ac
 			if (h->length < 0x16) break;
fc71ac
 			if (ver >= 0x0201)
fc71ac
 			{
fc71ac
@@ -4269,7 +4268,7 @@ static void dmi_decode(const struct dmi_header *h, u16 ver)
fc71ac
 			break;
fc71ac
 
fc71ac
 		case 14: /* 7.15 Group Associations */
fc71ac
-			printf("Group Associations\n");
fc71ac
+			pr_handle_name("Group Associations");
fc71ac
 			if (h->length < 0x05) break;
fc71ac
 			printf("\tName: %s\n",
fc71ac
 				dmi_string(h, data[0x04]));
fc71ac
@@ -4279,7 +4278,7 @@ static void dmi_decode(const struct dmi_header *h, u16 ver)
fc71ac
 			break;
fc71ac
 
fc71ac
 		case 15: /* 7.16 System Event Log */
fc71ac
-			printf("System Event Log\n");
fc71ac
+			pr_handle_name("System Event Log");
fc71ac
 			if (h->length < 0x14) break;
fc71ac
 			printf("\tArea Length: %u bytes\n",
fc71ac
 				WORD(data + 0x04));
fc71ac
@@ -4311,7 +4310,7 @@ static void dmi_decode(const struct dmi_header *h, u16 ver)
fc71ac
 			break;
fc71ac
 
fc71ac
 		case 16: /* 7.17 Physical Memory Array */
fc71ac
-			printf("Physical Memory Array\n");
fc71ac
+			pr_handle_name("Physical Memory Array");
fc71ac
 			if (h->length < 0x0F) break;
fc71ac
 			printf("\tLocation: %s\n",
fc71ac
 				dmi_memory_array_location(data[0x04]));
fc71ac
@@ -4347,7 +4346,7 @@ static void dmi_decode(const struct dmi_header *h, u16 ver)
fc71ac
 			break;
fc71ac
 
fc71ac
 		case 17: /* 7.18 Memory Device */
fc71ac
-			printf("Memory Device\n");
fc71ac
+			pr_handle_name("Memory Device");
fc71ac
 			if (h->length < 0x15) break;
fc71ac
 			if (!(opt.flags & FLAG_QUIET))
fc71ac
 			{
fc71ac
@@ -4457,7 +4456,7 @@ static void dmi_decode(const struct dmi_header *h, u16 ver)
fc71ac
 			break;
fc71ac
 
fc71ac
 		case 18: /* 7.19 32-bit Memory Error Information */
fc71ac
-			printf("32-bit Memory Error Information\n");
fc71ac
+			pr_handle_name("32-bit Memory Error Information");
fc71ac
 			if (h->length < 0x17) break;
fc71ac
 			printf("\tType: %s\n",
fc71ac
 				dmi_memory_error_type(data[0x04]));
fc71ac
@@ -4480,7 +4479,7 @@ static void dmi_decode(const struct dmi_header *h, u16 ver)
fc71ac
 			break;
fc71ac
 
fc71ac
 		case 19: /* 7.20 Memory Array Mapped Address */
fc71ac
-			printf("Memory Array Mapped Address\n");
fc71ac
+			pr_handle_name("Memory Array Mapped Address");
fc71ac
 			if (h->length < 0x0F) break;
fc71ac
 			if (h->length >= 0x1F && DWORD(data + 0x04) == 0xFFFFFFFF)
fc71ac
 			{
fc71ac
@@ -4516,7 +4515,7 @@ static void dmi_decode(const struct dmi_header *h, u16 ver)
fc71ac
 			break;
fc71ac
 
fc71ac
 		case 20: /* 7.21 Memory Device Mapped Address */
fc71ac
-			printf("Memory Device Mapped Address\n");
fc71ac
+			pr_handle_name("Memory Device Mapped Address");
fc71ac
 			if (h->length < 0x13) break;
fc71ac
 			if (h->length >= 0x23 && DWORD(data + 0x04) == 0xFFFFFFFF)
fc71ac
 			{
fc71ac
@@ -4559,7 +4558,7 @@ static void dmi_decode(const struct dmi_header *h, u16 ver)
fc71ac
 			break;
fc71ac
 
fc71ac
 		case 21: /* 7.22 Built-in Pointing Device */
fc71ac
-			printf("Built-in Pointing Device\n");
fc71ac
+			pr_handle_name("Built-in Pointing Device");
fc71ac
 			if (h->length < 0x07) break;
fc71ac
 			printf("\tType: %s\n",
fc71ac
 				dmi_pointing_device_type(data[0x04]));
fc71ac
@@ -4570,7 +4569,7 @@ static void dmi_decode(const struct dmi_header *h, u16 ver)
fc71ac
 			break;
fc71ac
 
fc71ac
 		case 22: /* 7.23 Portable Battery */
fc71ac
-			printf("Portable Battery\n");
fc71ac
+			pr_handle_name("Portable Battery");
fc71ac
 			if (h->length < 0x10) break;
fc71ac
 			printf("\tLocation: %s\n",
fc71ac
 				dmi_string(h, data[0x04]));
fc71ac
@@ -4618,7 +4617,7 @@ static void dmi_decode(const struct dmi_header *h, u16 ver)
fc71ac
 			break;
fc71ac
 
fc71ac
 		case 23: /* 7.24 System Reset */
fc71ac
-			printf("System Reset\n");
fc71ac
+			pr_handle_name("System Reset");
fc71ac
 			if (h->length < 0x0D) break;
fc71ac
 			printf("\tStatus: %s\n",
fc71ac
 				data[0x04] & (1 << 0) ? "Enabled" : "Disabled");
fc71ac
@@ -4645,7 +4644,7 @@ static void dmi_decode(const struct dmi_header *h, u16 ver)
fc71ac
 			break;
fc71ac
 
fc71ac
 		case 24: /* 7.25 Hardware Security */
fc71ac
-			printf("Hardware Security\n");
fc71ac
+			pr_handle_name("Hardware Security");
fc71ac
 			if (h->length < 0x05) break;
fc71ac
 			printf("\tPower-On Password Status: %s\n",
fc71ac
 				dmi_hardware_security_status(data[0x04] >> 6));
fc71ac
@@ -4658,7 +4657,7 @@ static void dmi_decode(const struct dmi_header *h, u16 ver)
fc71ac
 			break;
fc71ac
 
fc71ac
 		case 25: /* 7.26 System Power Controls */
fc71ac
-			printf("System Power Controls\n");
fc71ac
+			pr_handle_name("System Power Controls");
fc71ac
 			if (h->length < 0x09) break;
fc71ac
 			printf("\tNext Scheduled Power-on:");
fc71ac
 			dmi_power_controls_power_on(data + 0x04);
fc71ac
@@ -4666,7 +4665,7 @@ static void dmi_decode(const struct dmi_header *h, u16 ver)
fc71ac
 			break;
fc71ac
 
fc71ac
 		case 26: /* 7.27 Voltage Probe */
fc71ac
-			printf("Voltage Probe\n");
fc71ac
+			pr_handle_name("Voltage Probe");
fc71ac
 			if (h->length < 0x14) break;
fc71ac
 			printf("\tDescription: %s\n",
fc71ac
 				dmi_string(h, data[0x04]));
fc71ac
@@ -4698,7 +4697,7 @@ static void dmi_decode(const struct dmi_header *h, u16 ver)
fc71ac
 			break;
fc71ac
 
fc71ac
 		case 27: /* 7.28 Cooling Device */
fc71ac
-			printf("Cooling Device\n");
fc71ac
+			pr_handle_name("Cooling Device");
fc71ac
 			if (h->length < 0x0C) break;
fc71ac
 			if (!(opt.flags & FLAG_QUIET) && WORD(data + 0x04) != 0xFFFF)
fc71ac
 				printf("\tTemperature Probe Handle: 0x%04X\n",
fc71ac
@@ -4721,7 +4720,7 @@ static void dmi_decode(const struct dmi_header *h, u16 ver)
fc71ac
 			break;
fc71ac
 
fc71ac
 		case 28: /* 7.29 Temperature Probe */
fc71ac
-			printf("Temperature Probe\n");
fc71ac
+			pr_handle_name("Temperature Probe");
fc71ac
 			if (h->length < 0x14) break;
fc71ac
 			printf("\tDescription: %s\n",
fc71ac
 				dmi_string(h, data[0x04]));
fc71ac
@@ -4753,7 +4752,7 @@ static void dmi_decode(const struct dmi_header *h, u16 ver)
fc71ac
 			break;
fc71ac
 
fc71ac
 		case 29: /* 7.30 Electrical Current Probe */
fc71ac
-			printf("Electrical Current Probe\n");
fc71ac
+			pr_handle_name("Electrical Current Probe");
fc71ac
 			if (h->length < 0x14) break;
fc71ac
 			printf("\tDescription: %s\n",
fc71ac
 				dmi_string(h, data[0x04]));
fc71ac
@@ -4785,7 +4784,7 @@ static void dmi_decode(const struct dmi_header *h, u16 ver)
fc71ac
 			break;
fc71ac
 
fc71ac
 		case 30: /* 7.31 Out-of-band Remote Access */
fc71ac
-			printf("Out-of-band Remote Access\n");
fc71ac
+			pr_handle_name("Out-of-band Remote Access");
fc71ac
 			if (h->length < 0x06) break;
fc71ac
 			printf("\tManufacturer Name: %s\n",
fc71ac
 				dmi_string(h, data[0x04]));
fc71ac
@@ -4796,7 +4795,7 @@ static void dmi_decode(const struct dmi_header *h, u16 ver)
fc71ac
 			break;
fc71ac
 
fc71ac
 		case 31: /* 7.32 Boot Integrity Services Entry Point */
fc71ac
-			printf("Boot Integrity Services Entry Point\n");
fc71ac
+			pr_handle_name("Boot Integrity Services Entry Point");
fc71ac
 			if (h->length < 0x1C) break;
fc71ac
 			printf("\tChecksum: %s\n",
fc71ac
 				checksum(data, h->length) ? "OK" : "Invalid");
fc71ac
@@ -4808,14 +4807,14 @@ static void dmi_decode(const struct dmi_header *h, u16 ver)
fc71ac
 			break;
fc71ac
 
fc71ac
 		case 32: /* 7.33 System Boot Information */
fc71ac
-			printf("System Boot Information\n");
fc71ac
+			pr_handle_name("System Boot Information");
fc71ac
 			if (h->length < 0x0B) break;
fc71ac
 			printf("\tStatus: %s\n",
fc71ac
 				dmi_system_boot_status(data[0x0A]));
fc71ac
 			break;
fc71ac
 
fc71ac
 		case 33: /* 7.34 64-bit Memory Error Information */
fc71ac
-			printf("64-bit Memory Error Information\n");
fc71ac
+			pr_handle_name("64-bit Memory Error Information");
fc71ac
 			if (h->length < 0x1F) break;
fc71ac
 			printf("\tType: %s\n",
fc71ac
 				dmi_memory_error_type(data[0x04]));
fc71ac
@@ -4838,7 +4837,7 @@ static void dmi_decode(const struct dmi_header *h, u16 ver)
fc71ac
 			break;
fc71ac
 
fc71ac
 		case 34: /* 7.35 Management Device */
fc71ac
-			printf("Management Device\n");
fc71ac
+			pr_handle_name("Management Device");
fc71ac
 			if (h->length < 0x0B) break;
fc71ac
 			printf("\tDescription: %s\n",
fc71ac
 				dmi_string(h, data[0x04]));
fc71ac
@@ -4851,7 +4850,7 @@ static void dmi_decode(const struct dmi_header *h, u16 ver)
fc71ac
 			break;
fc71ac
 
fc71ac
 		case 35: /* 7.36 Management Device Component */
fc71ac
-			printf("Management Device Component\n");
fc71ac
+			pr_handle_name("Management Device Component");
fc71ac
 			if (h->length < 0x0B) break;
fc71ac
 			printf("\tDescription: %s\n",
fc71ac
 				dmi_string(h, data[0x04]));
fc71ac
@@ -4868,7 +4867,7 @@ static void dmi_decode(const struct dmi_header *h, u16 ver)
fc71ac
 			break;
fc71ac
 
fc71ac
 		case 36: /* 7.37 Management Device Threshold Data */
fc71ac
-			printf("Management Device Threshold Data\n");
fc71ac
+			pr_handle_name("Management Device Threshold Data");
fc71ac
 			if (h->length < 0x10) break;
fc71ac
 			if (WORD(data + 0x04) != 0x8000)
fc71ac
 				printf("\tLower Non-critical Threshold: %d\n",
fc71ac
@@ -4891,7 +4890,7 @@ static void dmi_decode(const struct dmi_header *h, u16 ver)
fc71ac
 			break;
fc71ac
 
fc71ac
 		case 37: /* 7.38 Memory Channel */
fc71ac
-			printf("Memory Channel\n");
fc71ac
+			pr_handle_name("Memory Channel");
fc71ac
 			if (h->length < 0x07) break;
fc71ac
 			printf("\tType: %s\n",
fc71ac
 				dmi_memory_channel_type(data[0x04]));
fc71ac
@@ -4908,7 +4907,7 @@ static void dmi_decode(const struct dmi_header *h, u16 ver)
fc71ac
 			 * We use the word "Version" instead of "Revision", conforming to
fc71ac
 			 * the IPMI specification.
fc71ac
 			 */
fc71ac
-			printf("IPMI Device Information\n");
fc71ac
+			pr_handle_name("IPMI Device Information");
fc71ac
 			if (h->length < 0x10) break;
fc71ac
 			printf("\tInterface Type: %s\n",
fc71ac
 				dmi_ipmi_interface_type(data[0x04]));
fc71ac
@@ -4946,7 +4945,7 @@ static void dmi_decode(const struct dmi_header *h, u16 ver)
fc71ac
 			break;
fc71ac
 
fc71ac
 		case 39: /* 7.40 System Power Supply */
fc71ac
-			printf("System Power Supply\n");
fc71ac
+			pr_handle_name("System Power Supply");
fc71ac
 			if (h->length < 0x10) break;
fc71ac
 			if (data[0x04] != 0x00)
fc71ac
 				printf("\tPower Unit Group: %u\n",
fc71ac
@@ -5006,7 +5005,7 @@ static void dmi_decode(const struct dmi_header *h, u16 ver)
fc71ac
 			break;
fc71ac
 
fc71ac
 		case 41: /* 7.42 Onboard Device Extended Information */
fc71ac
-			printf("Onboard Device\n");
fc71ac
+			pr_handle_name("Onboard Device");
fc71ac
 			if (h->length < 0x0B) break;
fc71ac
 			printf("\tReference Designation: %s\n", dmi_string(h, data[0x04]));
fc71ac
 			printf("\tType: %s\n",
fc71ac
@@ -5018,7 +5017,7 @@ static void dmi_decode(const struct dmi_header *h, u16 ver)
fc71ac
 			break;
fc71ac
 
fc71ac
 		case 42: /* 7.43 Management Controller Host Interface */
fc71ac
-			printf("Management Controller Host Interface\n");
fc71ac
+			pr_handle_name("Management Controller Host Interface");
fc71ac
 			if (ver < 0x0302)
fc71ac
 			{
fc71ac
 				if (h->length < 0x05) break;
fc71ac
@@ -5043,7 +5042,7 @@ static void dmi_decode(const struct dmi_header *h, u16 ver)
fc71ac
 			break;
fc71ac
 
fc71ac
 		case 43: /* 7.44 TPM Device */
fc71ac
-			printf("TPM Device\n");
fc71ac
+			pr_handle_name("TPM Device");
fc71ac
 			if (h->length < 0x1B) break;
fc71ac
 			printf("\tVendor ID:");
fc71ac
 			dmi_tpm_vendor_id(data + 0x04);
fc71ac
@@ -5080,11 +5079,11 @@ static void dmi_decode(const struct dmi_header *h, u16 ver)
fc71ac
 			break;
fc71ac
 
fc71ac
 		case 126: /* 7.44 Inactive */
fc71ac
-			printf("Inactive\n");
fc71ac
+			pr_handle_name("Inactive");
fc71ac
 			break;
fc71ac
 
fc71ac
 		case 127: /* 7.45 End Of Table */
fc71ac
-			printf("End Of Table\n");
fc71ac
+			pr_handle_name("End Of Table");
fc71ac
 			break;
fc71ac
 
fc71ac
 		default:
fc71ac
@@ -5092,7 +5091,7 @@ static void dmi_decode(const struct dmi_header *h, u16 ver)
fc71ac
 				break;
fc71ac
 			if (opt.flags & FLAG_QUIET)
fc71ac
 				return;
fc71ac
-			printf("%s Type\n",
fc71ac
+			pr_handle_name("%s Type",
fc71ac
 				h->type >= 128 ? "OEM-specific" : "Unknown");
fc71ac
 			dmi_dump(h, "\t");
fc71ac
 	}
fc71ac
diff --git a/dmioem.c b/dmioem.c
fc71ac
index 1a9bd8264fcb..c999c08c4475 100644
fc71ac
--- a/dmioem.c
fc71ac
+++ b/dmioem.c
fc71ac
@@ -25,6 +25,7 @@
fc71ac
 #include "types.h"
fc71ac
 #include "dmidecode.h"
fc71ac
 #include "dmioem.h"
fc71ac
+#include "dmioutput.h"
fc71ac
 
fc71ac
 /*
fc71ac
  * Globals for vendor-specific decodes
fc71ac
@@ -92,7 +93,7 @@ static int dmi_decode_acer(const struct dmi_header *h)
fc71ac
 			 * brands, including Fujitsu-Siemens, Medion, Lenovo,
fc71ac
 			 * and eMachines.
fc71ac
 			 */
fc71ac
-			printf("Acer Hotkey Function\n");
fc71ac
+			pr_handle_name("Acer Hotkey Function");
fc71ac
 			if (h->length < 0x0F) break;
fc71ac
 			cap = WORD(data + 0x04);
fc71ac
 			printf("\tFunction bitmap for Communication Button: 0x%04hx\n", cap);
fc71ac
@@ -157,7 +158,7 @@ static int dmi_decode_hp(const struct dmi_header *h)
fc71ac
 			/*
fc71ac
 			 * Vendor Specific: HPE ProLiant System/Rack Locator
fc71ac
 			 */
fc71ac
-			printf("%s ProLiant System/Rack Locator\n", company);
fc71ac
+			pr_handle_name("%s ProLiant System/Rack Locator", company);
fc71ac
 			if (h->length < 0x0B) break;
fc71ac
 			printf("\tRack Name: %s\n", dmi_string(h, data[0x04]));
fc71ac
 			printf("\tEnclosure Name: %s\n", dmi_string(h, data[0x05]));
fc71ac
@@ -189,10 +190,9 @@ static int dmi_decode_hp(const struct dmi_header *h)
fc71ac
 			 *
fc71ac
 			 * Type 221: is deprecated in the latest docs
fc71ac
 			 */
fc71ac
-			printf("%s %s\n", company,
fc71ac
-				h->type == 221 ?
fc71ac
-					"BIOS iSCSI NIC PCI and MAC Information" :
fc71ac
-					"BIOS PXE NIC PCI and MAC Information");
fc71ac
+			pr_handle_name("%s %s", company, h->type == 221 ?
fc71ac
+				       "BIOS iSCSI NIC PCI and MAC Information" :
fc71ac
+				       "BIOS PXE NIC PCI and MAC Information");
fc71ac
 			nic = 1;
fc71ac
 			ptr = 4;
fc71ac
 			while (h->length >= ptr + 8)
fc71ac
@@ -224,7 +224,8 @@ static int dmi_decode_hp(const struct dmi_header *h)
fc71ac
 			 *  0x08  |   MAC  | 32B   | MAC addr padded w/ 0s
fc71ac
 			 *  0x28  | Port No| BYTE  | Each NIC maps to a Port
fc71ac
 			 */
fc71ac
-			printf("%s BIOS PXE NIC PCI and MAC Information\n", company);
fc71ac
+			pr_handle_name("%s BIOS PXE NIC PCI and MAC Information",
fc71ac
+				       company);
fc71ac
 			if (h->length < 0x0E) break;
fc71ac
 			/* If the record isn't long enough, we don't have an ID
fc71ac
 			 * use 0xFF to use the internal counter.
fc71ac
@@ -240,7 +241,7 @@ static int dmi_decode_hp(const struct dmi_header *h)
fc71ac
 			 *
fc71ac
 			 * Source: hpwdt kernel driver
fc71ac
 			 */
fc71ac
-			printf("%s 64-bit CRU Information\n", company);
fc71ac
+			pr_handle_name("%s 64-bit CRU Information", company);
fc71ac
 			if (h->length < 0x18) break;
fc71ac
 			printf("\tSignature: 0x%08x", DWORD(data + 0x04));
fc71ac
 			if (is_printable(data + 0x04, 4))
fc71ac
@@ -265,7 +266,7 @@ static int dmi_decode_hp(const struct dmi_header *h)
fc71ac
 			 *
fc71ac
 			 * Source: hpwdt kernel driver
fc71ac
 			 */
fc71ac
-			printf("%s ProLiant Information\n", company);
fc71ac
+			pr_handle_name("%s ProLiant Information", company);
fc71ac
 			if (h->length < 0x08) break;
fc71ac
 			printf("\tPower Features: 0x%08x\n", DWORD(data + 0x04));
fc71ac
 			if (h->length < 0x0C) break;
fc71ac
@@ -318,7 +319,7 @@ static int dmi_decode_ibm_lenovo(const struct dmi_header *h)
fc71ac
 			 || strcmp(dmi_string(h, 1), "TVT-Enablement") != 0)
fc71ac
 				return 0;
fc71ac
 
fc71ac
-			printf("ThinkVantage Technologies\n");
fc71ac
+			pr_handle_name("ThinkVantage Technologies");
fc71ac
 			printf("\tVersion: %u\n", data[0x04]);
fc71ac
 			printf("\tDiagnostics: %s\n",
fc71ac
 				data[0x14] & 0x80 ? "Available" : "No");
fc71ac
@@ -357,7 +358,7 @@ static int dmi_decode_ibm_lenovo(const struct dmi_header *h)
fc71ac
 			if (data[0x06] != 0x07 || data[0x07] != 0x03 || data[0x08] != 0x01)
fc71ac
 				return 0;
fc71ac
 
fc71ac
-			printf("ThinkPad Device Presence Detection\n");
fc71ac
+			pr_handle_name("ThinkPad Device Presence Detection");
fc71ac
 			printf("\tFingerprint Reader: %s\n",
fc71ac
 				data[0x09] & 0x01 ? "Present" : "No");
fc71ac
 			break;
fc71ac
@@ -390,7 +391,7 @@ static int dmi_decode_ibm_lenovo(const struct dmi_header *h)
fc71ac
 			if (data[0x0A] != 0x0B || data[0x0B] != 0x07 || data[0x0C] != 0x01)
fc71ac
 				return 0;
fc71ac
 
fc71ac
-			printf("ThinkPad Embedded Controller Program\n");
fc71ac
+			pr_handle_name("ThinkPad Embedded Controller Program");
fc71ac
 			printf("\tVersion ID: %s\n", dmi_string(h, 1));
fc71ac
 			printf("\tRelease Date: %s\n", dmi_string(h, 2));
fc71ac
 			break;
fc71ac
diff --git a/dmioutput.c b/dmioutput.c
fc71ac
index ad3b0398c446..ca7edab5cc69 100644
fc71ac
--- a/dmioutput.c
fc71ac
+++ b/dmioutput.c
fc71ac
@@ -49,3 +49,13 @@ void pr_handle(const struct dmi_header *h)
fc71ac
 	printf("Handle 0x%04X, DMI type %d, %d bytes\n",
fc71ac
 	       h->handle, h->type, h->length);
fc71ac
 }
fc71ac
+
fc71ac
+void pr_handle_name(const char *format, ...)
fc71ac
+{
fc71ac
+	va_list args;
fc71ac
+
fc71ac
+	va_start(args, format);
fc71ac
+	vprintf(format, args);
fc71ac
+	va_end(args);
fc71ac
+	printf("\n");
fc71ac
+}
fc71ac
diff --git a/dmioutput.h b/dmioutput.h
fc71ac
index 6ef60f0ee3cd..0acdce7658c9 100644
fc71ac
--- a/dmioutput.h
fc71ac
+++ b/dmioutput.h
fc71ac
@@ -24,3 +24,4 @@
fc71ac
 void pr_comment(const char *format, ...);
fc71ac
 void pr_info(const char *format, ...);
fc71ac
 void pr_handle(const struct dmi_header *h);
fc71ac
+void pr_handle_name(const char *format, ...);
fc71ac
-- 
fc71ac
2.17.1
fc71ac