From: Labun, Marcin Date: Sun, 20 Mar 2011 04:47:33 +0000 (+1100) Subject: platform_intel: support EFI SCU OEM variable X-Git-Tag: mdadm-3.2.1~26 X-Git-Url: http://git.ipfire.org/?p=thirdparty%2Fmdadm.git;a=commitdiff_plain;h=8a0bf4f378c8b9c6bf28b65542c8354eee836c7e platform_intel: support EFI SCU OEM variable RstScuV and RstScuO variable names are supported. First try reading from RstScuV, when it fails try RstScuO. Signed-off-by: Marcin Labun Tested-by: Przemyslaw Czarnowski Signed-off-by: NeilBrown --- diff --git a/platform-intel.c b/platform-intel.c index 8003da6e..64542b9b 100644 --- a/platform-intel.c +++ b/platform-intel.c @@ -349,6 +349,7 @@ static const struct imsm_orom *find_imsm_hba_orom(enum sys_dev_type hba_id) #define SYS_EFI_VAR_PATH "/sys/firmware/efi/vars" #define SCU_PROP "RstScuV" +#define SCU_PROP_OEM "RstScuO" #define AHCI_PROP "RstSataV" #define VENDOR_GUID \ @@ -393,8 +394,14 @@ const struct imsm_orom *find_imsm_efi(enum sys_dev_type hba_id) snprintf(path, PATH_MAX, "%s/%s-%s", SYS_EFI_VAR_PATH, AHCI_PROP, guid_str(buf, VENDOR_GUID)); dprintf("EFI VAR: path=%s\n", path); - - if ((dfd = open(path, O_RDONLY)) < 0) { + dfd = open(path, O_RDONLY); + if ((dfd < 0) && (hba_id == SYS_DEV_SAS)) { + /* check OEM parameters */ + snprintf(path, PATH_MAX, "%s/%s-%s", SYS_EFI_VAR_PATH, SCU_PROP_OEM, guid_str(buf, VENDOR_GUID)); + dfd = open(path, O_RDONLY); + dprintf("EFI VAR: path=%s\n", path); + } + if (dfd < 0) { populated_efi[hba_id] = 0; return NULL; }