diff options
author | Matt Fleming <[email protected]> | 2013-03-05 07:40:16 +0000 |
---|---|---|
committer | Matt Fleming <[email protected]> | 2013-03-06 14:46:04 +0000 |
commit | 123abd76edf56c02a76b46d3d673897177ef067b (patch) | |
tree | 1aba3ae5759b447af561c6d296c4febb32f8dba8 /drivers/scsi/mpt2sas/mpi/mpi2_raid.h | |
parent | 68d929862e29a8b52a7f2f2f86a0600423b093cd (diff) |
efivars: efivarfs_valid_name() should handle pstore syntax
Stricter validation was introduced with commit da27a24383b2b
("efivarfs: guid part of filenames are case-insensitive") and commit
47f531e8ba3b ("efivarfs: Validate filenames much more aggressively"),
which is necessary for the guid portion of efivarfs filenames, but we
don't need to be so strict with the first part, the variable name. The
UEFI specification doesn't impose any constraints on variable names
other than they be a NULL-terminated string.
The above commits caused a regression that resulted in users seeing
the following message,
$ sudo mount -v /sys/firmware/efi/efivars mount: Cannot allocate memory
whenever pstore EFI variables were present in the variable store,
since their variable names failed to pass the following check,
/* GUID should be right after the first '-' */
if (s - 1 != strchr(str, '-'))
as a typical pstore filename is of the form, dump-type0-10-1-<guid>.
The fix is trivial since the guid portion of the filename is GUID_LEN
bytes, we can use (len - GUID_LEN) to ensure the '-' character is
where we expect it to be.
(The bogus ENOMEM error value will be fixed in a separate patch.)
Reported-by: Joseph Yasi <[email protected]>
Tested-by: Joseph Yasi <[email protected]>
Reported-by: Lingzhu Xiang <[email protected]>
Cc: Josh Boyer <[email protected]>
Cc: Jeremy Kerr <[email protected]>
Cc: Matthew Garrett <[email protected]>
Cc: <[email protected]> # v3.8
Signed-off-by: Matt Fleming <[email protected]>
Diffstat (limited to 'drivers/scsi/mpt2sas/mpi/mpi2_raid.h')
0 files changed, 0 insertions, 0 deletions