]> git.ipfire.org Git - thirdparty/lldpd.git/commitdiff
freebsd: add DMI support
authorVincent Bernat <bernat@luffy.cx>
Sat, 29 Dec 2012 17:48:46 +0000 (18:48 +0100)
committerVincent Bernat <bernat@luffy.cx>
Sat, 29 Dec 2012 17:48:46 +0000 (18:48 +0100)
src/daemon/Makefile.am
src/daemon/dmi-dummy.c [new file with mode: 0644]
src/daemon/dmi-freebsd.c [new file with mode: 0644]
src/daemon/dmi-linux.c [moved from src/daemon/dmi.c with 96% similarity]

index 8d028633cfb44cba62a83cd79bbfee1ec3cb942c..10962eb897bc454554bbbd47fe13e0f9f501323c 100644 (file)
@@ -14,7 +14,6 @@ liblldpd_la_SOURCES  = \
        edp.c edp.h \
        client.c \
        priv.c privsep_fdpass.c \
-       dmi.c \
        interfaces.c \
        event.c lldpd.c
 liblldpd_la_CFLAGS   = $(AM_CFLAGS) @LIBEVENT_CFLAGS@
@@ -25,16 +24,23 @@ liblldpd_la_LIBADD   = \
 if HOST_OS_LINUX
 liblldpd_la_SOURCES += \
        interfaces-linux.c \
-       netlink.c
+       netlink.c \
+       dmi-linux.c
 endif
 if HOST_OS_FREEBSD
-liblldpd_la_SOURCES += interfaces-bsd.c
+liblldpd_la_SOURCES += \
+       interfaces-bsd.c \
+       dmi-freebsd.c
 endif
 if HOST_OS_OPENBSD
-liblldpd_la_SOURCES += interfaces-bsd.c
+liblldpd_la_SOURCES += \
+       interfaces-bsd.c \
+       dmi-dummy.c
 endif
 if HOST_OS_NETBSD
-liblldpd_la_SOURCES += interfaces-bsd.c
+liblldpd_la_SOURCES += \
+       interfaces-bsd.c \
+       dmi-dummy.c
 endif
 
 # Add SNMP support if needed
diff --git a/src/daemon/dmi-dummy.c b/src/daemon/dmi-dummy.c
new file mode 100644 (file)
index 0000000..65a68b8
--- /dev/null
@@ -0,0 +1,57 @@
+/* -*- mode: c; c-file-style: "openbsd" -*- */
+/*
+ * Copyright (c) 2012 Vincent Bernat <bernat@luffy.cx>
+ *
+ * Permission to use, copy, modify, and/or distribute this software for any
+ * purpose with or without fee is hereby granted, provided that the above
+ * copyright notice and this permission notice appear in all copies.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+ * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+ * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+ * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+ * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+ * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+ * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+ */
+
+#include "lldpd.h"
+
+#ifdef ENABLE_LLDPMED
+
+char*
+dmi_hw()
+{
+       return NULL;
+}
+
+char*
+dmi_fw()
+{
+       return NULL;
+}
+
+char*
+dmi_sn()
+{
+       return NULL;
+}
+
+char*
+dmi_manuf()
+{
+       return NULL;
+}
+
+char*
+dmi_model()
+{
+       return NULL;
+}
+
+char*
+dmi_asset()
+{
+       return NULL;
+}
+#endif
diff --git a/src/daemon/dmi-freebsd.c b/src/daemon/dmi-freebsd.c
new file mode 100644 (file)
index 0000000..7c4a0af
--- /dev/null
@@ -0,0 +1,83 @@
+/* -*- mode: c; c-file-style: "openbsd" -*- */
+/*
+ * Copyright (c) 2012 Vincent Bernat <bernat@luffy.cx>
+ *
+ * Permission to use, copy, modify, and/or distribute this software for any
+ * purpose with or without fee is hereby granted, provided that the above
+ * copyright notice and this permission notice appear in all copies.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+ * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+ * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+ * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+ * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+ * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+ * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+ */
+
+#include "lldpd.h"
+#include <unistd.h>
+#include <kenv.h>
+
+#ifdef ENABLE_LLDPMED
+       /* Fill in inventory stuff:
+           - hardware version: smbios.system.version
+           - firmware version: smbios.bios.version
+           - software version: `uname -r`
+           - serial number: smbios.system.serial
+           - manufacturer: smbios.system.maker
+           - model: smbios.system.product
+           - asset: smbios.chassis.tag
+       */
+
+static char*
+dmi_get(char *file)
+{
+       char buffer[100] = {};
+
+       log_debug("localchassis", "DMI request for %s", file);
+       if (kenv(KENV_GET, file, buffer, sizeof(buffer) - 1) == -1) {
+               log_debug("localchassis", "cannot get %s", file);
+               return NULL;
+       }
+       if (strlen(buffer))
+               return strdup(buffer);
+       return NULL;
+}
+
+char*
+dmi_hw()
+{
+       return dmi_get("smbios.system.version");
+}
+
+char*
+dmi_fw()
+{
+       return dmi_get("smbios.bios.version");
+}
+
+char*
+dmi_sn()
+{
+       return dmi_get("smbios.system.serial");
+}
+
+char*
+dmi_manuf()
+{
+       return dmi_get("smbios.system.maker");
+}
+
+char*
+dmi_model()
+{
+       return dmi_get("smibios.system.product");
+}
+
+char*
+dmi_asset()
+{
+       return dmi_get("smibios.chassis.tag");
+}
+#endif
similarity index 96%
rename from src/daemon/dmi.c
rename to src/daemon/dmi-linux.c
index b8d242f3673d1f1f7b72eb4e77040f258412cbc9..9fe2801f0cd58779b65d0aac9b68d8be277d0f2b 100644 (file)
@@ -29,8 +29,7 @@
            - asset: /sys/class/dmi/id/chassis_asset_tag
        */
 
-#ifdef HOST_OS_LINUX
-char*
+static char*
 dmi_get(char *file)
 {
        int dmi, s;
@@ -55,14 +54,6 @@ dmi_get(char *file)
                return strdup(buffer);
        return NULL;
 }
-#else
-char *
-dmi_get(char *file)
-{
-       return NULL;
-}
-#endif
-
 
 char*
 dmi_hw()