From 899f5b8ab233987646e6f5012f462a19a833d8d4 Mon Sep 17 00:00:00 2001 From: Michael Brown Date: Wed, 21 Nov 2007 02:27:07 +0000 Subject: Added definition of a UUID and uuid_ntoa() (for debugging), and implemented smbios_get_uuid(). --- src/arch/i386/firmware/pcbios/smbios.c | 27 ++++++++------------------- src/arch/i386/include/smbios.h | 2 ++ 2 files changed, 10 insertions(+), 19 deletions(-) (limited to 'src/arch') diff --git a/src/arch/i386/firmware/pcbios/smbios.c b/src/arch/i386/firmware/pcbios/smbios.c index 78a74804..d8be6f8b 100644 --- a/src/arch/i386/firmware/pcbios/smbios.c +++ b/src/arch/i386/firmware/pcbios/smbios.c @@ -21,6 +21,7 @@ #include #include #include +#include #include #include #include @@ -301,34 +302,22 @@ int find_smbios_string ( struct smbios_strings *strings, unsigned int index, } /** - * Find SMBIOS serial number + * Get UUID from SMBIOS * + * @v uuid UUID to fill in + * @ret rc Return status code */ -int dump_smbios_info ( void ) { +int smbios_get_uuid ( union uuid *uuid ) { struct smbios_system_information sysinfo; - struct smbios_strings strings; - char buf[64]; int rc; if ( ( rc = find_smbios_structure ( SMBIOS_TYPE_SYSTEM_INFORMATION, &sysinfo, sizeof ( sysinfo ), - &strings ) ) != 0 ) - return rc; - - DBG_HD ( &sysinfo, sizeof ( sysinfo ) ); - - if ( ( rc = find_smbios_string ( &strings, sysinfo.manufacturer, - buf, sizeof ( buf ) ) ) != 0 ) - return rc; - DBG ( "Manufacturer: \"%s\"\n", buf ); - - if ( ( rc = find_smbios_string ( &strings, sysinfo.product, - buf, sizeof ( buf ) ) ) != 0 ) + NULL ) ) != 0 ) return rc; - DBG ( "Product: \"%s\"\n", buf ); - DBG ( "UUID:\n" ); - DBG_HD ( &sysinfo.uuid, sizeof ( sysinfo.uuid ) ); + memcpy ( uuid, sysinfo.uuid, sizeof ( *uuid ) ); + DBG ( "SMBIOS found UUID %s\n", uuid_ntoa ( uuid ) ); return 0; } diff --git a/src/arch/i386/include/smbios.h b/src/arch/i386/include/smbios.h index a0a7a222..f5f0b5c2 100644 --- a/src/arch/i386/include/smbios.h +++ b/src/arch/i386/include/smbios.h @@ -32,6 +32,8 @@ struct smbios_system_information { uint8_t serial; /** UUID */ uint8_t uuid[16]; + /** Wake-up type */ + uint8_t wakeup; } __attribute__ (( packed )); /** SMBIOS system information structure type */ -- cgit v1.2.3-55-g7522