Module Name:    src
Committed By:   mlelstv
Date:           Mon Dec 29 14:00:26 UTC 2014

Modified Files:
        src/sys/arch/x86/x86: ipmi.c

Log Message:
Avoid NULL pointer dereference if SMBIOS key "system-product" does not
exist.


To generate a diff of this commit:
cvs rdiff -u -r1.59 -r1.60 src/sys/arch/x86/x86/ipmi.c

Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.

Modified files:

Index: src/sys/arch/x86/x86/ipmi.c
diff -u src/sys/arch/x86/x86/ipmi.c:1.59 src/sys/arch/x86/x86/ipmi.c:1.60
--- src/sys/arch/x86/x86/ipmi.c:1.59	Mon Sep 22 13:30:55 2014
+++ src/sys/arch/x86/x86/ipmi.c	Mon Dec 29 14:00:26 2014
@@ -1,4 +1,4 @@
-/*	$NetBSD: ipmi.c,v 1.59 2014/09/22 13:30:55 nat Exp $ */
+/*	$NetBSD: ipmi.c,v 1.60 2014/12/29 14:00:26 mlelstv Exp $ */
 
 /*
  * Copyright (c) 2006 Manuel Bouyer.
@@ -52,7 +52,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: ipmi.c,v 1.59 2014/09/22 13:30:55 nat Exp $");
+__KERNEL_RCSID(0, "$NetBSD: ipmi.c,v 1.60 2014/12/29 14:00:26 mlelstv Exp $");
 
 #include <sys/types.h>
 #include <sys/param.h>
@@ -891,6 +891,7 @@ dumpb(const char *lbl, int len, const ui
 void
 ipmi_smbios_probe(struct smbios_ipmi *pipmi, struct ipmi_attach_args *ia)
 {
+	const char *platform;
 
 	dbg_printf(1, "ipmi_smbios_probe: %02x %02x %02x %02x "
 	    "%08" PRIx64 " %02x %02x\n",
@@ -938,8 +939,9 @@ ipmi_smbios_probe(struct smbios_ipmi *pi
 	if (pipmi->smipmi_base_flags & SMIPMI_FLAG_ODDOFFSET)
 		ia->iaa_if_iobase++;
 
-	if (strcmp(pmf_get_platform("system-product"),
-            "ProLiant MicroServer") == 0) {
+	platform = pmf_get_platform("system-product");
+	if (platform != NULL &&
+	    strcmp(platform, "ProLiant MicroServer") == 0) {
                 ia->iaa_if_iospacing = 1;
                 ia->iaa_if_iobase = pipmi->smipmi_base_address - 7;
                 ia->iaa_if_iotype = 'i';

Reply via email to