Commit dabe5896 authored by Linus Torvalds's avatar Linus Torvalds

Merge branch 'efi-urgent-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip

Pull EFI fixes from Ingo Molnar:
 "Misc fixes: world-readable pointer removal from sysfs, a ESRT kfree()
  bug fix and a comment update"

* 'efi-urgent-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip:
  efi: Add comment to avoid future expanding of sysfs systab
  efi/esrt: Use memunmap() instead of kfree() to free the remapping
  efi: Move some sysfs files to be read-only by root
parents 07eca14b 0b02e448
...@@ -109,6 +109,8 @@ struct kobject *efi_kobj; ...@@ -109,6 +109,8 @@ struct kobject *efi_kobj;
/* /*
* Let's not leave out systab information that snuck into * Let's not leave out systab information that snuck into
* the efivars driver * the efivars driver
* Note, do not add more fields in systab sysfs file as it breaks sysfs
* one value per file rule!
*/ */
static ssize_t systab_show(struct kobject *kobj, static ssize_t systab_show(struct kobject *kobj,
struct kobj_attribute *attr, char *buf) struct kobj_attribute *attr, char *buf)
...@@ -143,8 +145,7 @@ static ssize_t systab_show(struct kobject *kobj, ...@@ -143,8 +145,7 @@ static ssize_t systab_show(struct kobject *kobj,
return str - buf; return str - buf;
} }
static struct kobj_attribute efi_attr_systab = static struct kobj_attribute efi_attr_systab = __ATTR_RO_MODE(systab, 0400);
__ATTR(systab, 0400, systab_show, NULL);
#define EFI_FIELD(var) efi.var #define EFI_FIELD(var) efi.var
......
...@@ -106,7 +106,7 @@ static const struct sysfs_ops esre_attr_ops = { ...@@ -106,7 +106,7 @@ static const struct sysfs_ops esre_attr_ops = {
}; };
/* Generic ESRT Entry ("ESRE") support. */ /* Generic ESRT Entry ("ESRE") support. */
static ssize_t esre_fw_class_show(struct esre_entry *entry, char *buf) static ssize_t fw_class_show(struct esre_entry *entry, char *buf)
{ {
char *str = buf; char *str = buf;
...@@ -117,18 +117,16 @@ static ssize_t esre_fw_class_show(struct esre_entry *entry, char *buf) ...@@ -117,18 +117,16 @@ static ssize_t esre_fw_class_show(struct esre_entry *entry, char *buf)
return str - buf; return str - buf;
} }
static struct esre_attribute esre_fw_class = __ATTR(fw_class, 0400, static struct esre_attribute esre_fw_class = __ATTR_RO_MODE(fw_class, 0400);
esre_fw_class_show, NULL);
#define esre_attr_decl(name, size, fmt) \ #define esre_attr_decl(name, size, fmt) \
static ssize_t esre_##name##_show(struct esre_entry *entry, char *buf) \ static ssize_t name##_show(struct esre_entry *entry, char *buf) \
{ \ { \
return sprintf(buf, fmt "\n", \ return sprintf(buf, fmt "\n", \
le##size##_to_cpu(entry->esre.esre1->name)); \ le##size##_to_cpu(entry->esre.esre1->name)); \
} \ } \
\ \
static struct esre_attribute esre_##name = __ATTR(name, 0400, \ static struct esre_attribute esre_##name = __ATTR_RO_MODE(name, 0400)
esre_##name##_show, NULL)
esre_attr_decl(fw_type, 32, "%u"); esre_attr_decl(fw_type, 32, "%u");
esre_attr_decl(fw_version, 32, "%u"); esre_attr_decl(fw_version, 32, "%u");
...@@ -193,14 +191,13 @@ static int esre_create_sysfs_entry(void *esre, int entry_num) ...@@ -193,14 +191,13 @@ static int esre_create_sysfs_entry(void *esre, int entry_num)
/* support for displaying ESRT fields at the top level */ /* support for displaying ESRT fields at the top level */
#define esrt_attr_decl(name, size, fmt) \ #define esrt_attr_decl(name, size, fmt) \
static ssize_t esrt_##name##_show(struct kobject *kobj, \ static ssize_t name##_show(struct kobject *kobj, \
struct kobj_attribute *attr, char *buf)\ struct kobj_attribute *attr, char *buf)\
{ \ { \
return sprintf(buf, fmt "\n", le##size##_to_cpu(esrt->name)); \ return sprintf(buf, fmt "\n", le##size##_to_cpu(esrt->name)); \
} \ } \
\ \
static struct kobj_attribute esrt_##name = __ATTR(name, 0400, \ static struct kobj_attribute esrt_##name = __ATTR_RO_MODE(name, 0400)
esrt_##name##_show, NULL)
esrt_attr_decl(fw_resource_count, 32, "%u"); esrt_attr_decl(fw_resource_count, 32, "%u");
esrt_attr_decl(fw_resource_count_max, 32, "%u"); esrt_attr_decl(fw_resource_count_max, 32, "%u");
...@@ -431,7 +428,7 @@ static int __init esrt_sysfs_init(void) ...@@ -431,7 +428,7 @@ static int __init esrt_sysfs_init(void)
err_remove_esrt: err_remove_esrt:
kobject_put(esrt_kobj); kobject_put(esrt_kobj);
err: err:
kfree(esrt); memunmap(esrt);
esrt = NULL; esrt = NULL;
return error; return error;
} }
......
...@@ -63,11 +63,11 @@ static ssize_t map_attr_show(struct kobject *kobj, struct attribute *attr, ...@@ -63,11 +63,11 @@ static ssize_t map_attr_show(struct kobject *kobj, struct attribute *attr,
return map_attr->show(entry, buf); return map_attr->show(entry, buf);
} }
static struct map_attribute map_type_attr = __ATTR_RO(type); static struct map_attribute map_type_attr = __ATTR_RO_MODE(type, 0400);
static struct map_attribute map_phys_addr_attr = __ATTR_RO(phys_addr); static struct map_attribute map_phys_addr_attr = __ATTR_RO_MODE(phys_addr, 0400);
static struct map_attribute map_virt_addr_attr = __ATTR_RO(virt_addr); static struct map_attribute map_virt_addr_attr = __ATTR_RO_MODE(virt_addr, 0400);
static struct map_attribute map_num_pages_attr = __ATTR_RO(num_pages); static struct map_attribute map_num_pages_attr = __ATTR_RO_MODE(num_pages, 0400);
static struct map_attribute map_attribute_attr = __ATTR_RO(attribute); static struct map_attribute map_attribute_attr = __ATTR_RO_MODE(attribute, 0400);
/* /*
* These are default attributes that are added for every memmap entry. * These are default attributes that are added for every memmap entry.
......
...@@ -117,6 +117,12 @@ struct attribute_group { ...@@ -117,6 +117,12 @@ struct attribute_group {
.show = _name##_show, \ .show = _name##_show, \
} }
#define __ATTR_RO_MODE(_name, _mode) { \
.attr = { .name = __stringify(_name), \
.mode = VERIFY_OCTAL_PERMISSIONS(_mode) }, \
.show = _name##_show, \
}
#define __ATTR_WO(_name) { \ #define __ATTR_WO(_name) { \
.attr = { .name = __stringify(_name), .mode = S_IWUSR }, \ .attr = { .name = __stringify(_name), .mode = S_IWUSR }, \
.store = _name##_store, \ .store = _name##_store, \
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment