diff options
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/firmware/efivars.c | 51 |
1 files changed, 23 insertions, 28 deletions
diff --git a/drivers/firmware/efivars.c b/drivers/firmware/efivars.c index 06ecdb9f6013..82183c28a12a 100644 --- a/drivers/firmware/efivars.c +++ b/drivers/firmware/efivars.c | |||
@@ -143,13 +143,6 @@ struct efivar_attribute efivar_attr_##_name = { \ | |||
143 | .store = _store, \ | 143 | .store = _store, \ |
144 | }; | 144 | }; |
145 | 145 | ||
146 | #define VAR_SUBSYS_ATTR(_name, _mode, _show, _store) \ | ||
147 | struct subsys_attribute var_subsys_attr_##_name = { \ | ||
148 | .attr = {.name = __stringify(_name), .mode = _mode}, \ | ||
149 | .show = _show, \ | ||
150 | .store = _store, \ | ||
151 | }; | ||
152 | |||
153 | #define to_efivar_attr(_attr) container_of(_attr, struct efivar_attribute, attr) | 146 | #define to_efivar_attr(_attr) container_of(_attr, struct efivar_attribute, attr) |
154 | #define to_efivar_entry(obj) container_of(obj, struct efivar_entry, kobj) | 147 | #define to_efivar_entry(obj) container_of(obj, struct efivar_entry, kobj) |
155 | 148 | ||
@@ -408,12 +401,6 @@ static struct kobj_type efivar_ktype = { | |||
408 | .default_attrs = def_attrs, | 401 | .default_attrs = def_attrs, |
409 | }; | 402 | }; |
410 | 403 | ||
411 | static ssize_t | ||
412 | dummy(struct kset *kset, char *buf) | ||
413 | { | ||
414 | return -ENODEV; | ||
415 | } | ||
416 | |||
417 | static inline void | 404 | static inline void |
418 | efivar_unregister(struct efivar_entry *var) | 405 | efivar_unregister(struct efivar_entry *var) |
419 | { | 406 | { |
@@ -421,8 +408,9 @@ efivar_unregister(struct efivar_entry *var) | |||
421 | } | 408 | } |
422 | 409 | ||
423 | 410 | ||
424 | static ssize_t | 411 | static ssize_t efivar_create(struct kobject *kobj, |
425 | efivar_create(struct kset *kset, const char *buf, size_t count) | 412 | struct bin_attribute *bin_attr, |
413 | char *buf, loff_t pos, size_t count) | ||
426 | { | 414 | { |
427 | struct efi_variable *new_var = (struct efi_variable *)buf; | 415 | struct efi_variable *new_var = (struct efi_variable *)buf; |
428 | struct efivar_entry *search_efivar, *n; | 416 | struct efivar_entry *search_efivar, *n; |
@@ -479,8 +467,9 @@ efivar_create(struct kset *kset, const char *buf, size_t count) | |||
479 | return count; | 467 | return count; |
480 | } | 468 | } |
481 | 469 | ||
482 | static ssize_t | 470 | static ssize_t efivar_delete(struct kobject *kobj, |
483 | efivar_delete(struct kset *kset, const char *buf, size_t count) | 471 | struct bin_attribute *bin_attr, |
472 | char *buf, loff_t pos, size_t count) | ||
484 | { | 473 | { |
485 | struct efi_variable *del_var = (struct efi_variable *)buf; | 474 | struct efi_variable *del_var = (struct efi_variable *)buf; |
486 | struct efivar_entry *search_efivar, *n; | 475 | struct efivar_entry *search_efivar, *n; |
@@ -537,13 +526,14 @@ efivar_delete(struct kset *kset, const char *buf, size_t count) | |||
537 | return count; | 526 | return count; |
538 | } | 527 | } |
539 | 528 | ||
540 | static VAR_SUBSYS_ATTR(new_var, 0200, dummy, efivar_create); | 529 | static struct bin_attribute var_subsys_attr_new_var = { |
541 | static VAR_SUBSYS_ATTR(del_var, 0200, dummy, efivar_delete); | 530 | .attr = {.name = "new_var", .mode = 0200}, |
531 | .write = efivar_create, | ||
532 | }; | ||
542 | 533 | ||
543 | static struct subsys_attribute *var_subsys_attrs[] = { | 534 | static struct bin_attribute var_subsys_attr_del_var = { |
544 | &var_subsys_attr_new_var, | 535 | .attr = {.name = "del_var", .mode = 0200}, |
545 | &var_subsys_attr_del_var, | 536 | .write = efivar_delete, |
546 | NULL, | ||
547 | }; | 537 | }; |
548 | 538 | ||
549 | /* | 539 | /* |
@@ -728,11 +718,16 @@ efivars_init(void) | |||
728 | * Now add attributes to allow creation of new vars | 718 | * Now add attributes to allow creation of new vars |
729 | * and deletion of existing ones... | 719 | * and deletion of existing ones... |
730 | */ | 720 | */ |
731 | 721 | error = sysfs_create_bin_file(&vars_subsys.kobj, | |
732 | for (i = 0; (attr = var_subsys_attrs[i]) && !error; i++) { | 722 | &var_subsys_attr_new_var); |
733 | if (attr->show && attr->store) | 723 | if (error) |
734 | error = subsys_create_file(&vars_subsys, attr); | 724 | printk(KERN_ERR "efivars: unable to create new_var sysfs file" |
735 | } | 725 | " due to error %d\n", error); |
726 | error = sysfs_create_bin_file(&vars_subsys.kobj, | ||
727 | &var_subsys_attr_del_var); | ||
728 | if (error) | ||
729 | printk(KERN_ERR "efivars: unable to create del_var sysfs file" | ||
730 | " due to error %d\n", error); | ||
736 | 731 | ||
737 | /* Don't forget the systab entry */ | 732 | /* Don't forget the systab entry */ |
738 | 733 | ||