diff options
Diffstat (limited to 'drivers/pci/hotplug/ibmphp_ebda.c')
-rw-r--r-- | drivers/pci/hotplug/ibmphp_ebda.c | 19 |
1 files changed, 7 insertions, 12 deletions
diff --git a/drivers/pci/hotplug/ibmphp_ebda.c b/drivers/pci/hotplug/ibmphp_ebda.c index 8cfd1c4926c8..c1abac8ab5c3 100644 --- a/drivers/pci/hotplug/ibmphp_ebda.c +++ b/drivers/pci/hotplug/ibmphp_ebda.c | |||
@@ -587,11 +587,14 @@ static u8 calculate_first_slot (u8 slot_num) | |||
587 | return first_slot + 1; | 587 | return first_slot + 1; |
588 | 588 | ||
589 | } | 589 | } |
590 | |||
591 | #define SLOT_NAME_SIZE 30 | ||
592 | |||
590 | static char *create_file_name (struct slot * slot_cur) | 593 | static char *create_file_name (struct slot * slot_cur) |
591 | { | 594 | { |
592 | struct opt_rio *opt_vg_ptr = NULL; | 595 | struct opt_rio *opt_vg_ptr = NULL; |
593 | struct opt_rio_lo *opt_lo_ptr = NULL; | 596 | struct opt_rio_lo *opt_lo_ptr = NULL; |
594 | static char str[30]; | 597 | static char str[SLOT_NAME_SIZE]; |
595 | int which = 0; /* rxe = 1, chassis = 0 */ | 598 | int which = 0; /* rxe = 1, chassis = 0 */ |
596 | u8 number = 1; /* either chassis or rxe # */ | 599 | u8 number = 1; /* either chassis or rxe # */ |
597 | u8 first_slot = 1; | 600 | u8 first_slot = 1; |
@@ -703,7 +706,6 @@ static void release_slot(struct hotplug_slot *hotplug_slot) | |||
703 | 706 | ||
704 | slot = hotplug_slot->private; | 707 | slot = hotplug_slot->private; |
705 | kfree(slot->hotplug_slot->info); | 708 | kfree(slot->hotplug_slot->info); |
706 | kfree(slot->hotplug_slot->name); | ||
707 | kfree(slot->hotplug_slot); | 709 | kfree(slot->hotplug_slot); |
708 | slot->ctrl = NULL; | 710 | slot->ctrl = NULL; |
709 | slot->bus_on = NULL; | 711 | slot->bus_on = NULL; |
@@ -734,6 +736,7 @@ static int __init ebda_rsrc_controller (void) | |||
734 | struct bus_info *bus_info_ptr1, *bus_info_ptr2; | 736 | struct bus_info *bus_info_ptr1, *bus_info_ptr2; |
735 | int rc; | 737 | int rc; |
736 | struct slot *tmp_slot; | 738 | struct slot *tmp_slot; |
739 | char name[SLOT_NAME_SIZE]; | ||
737 | 740 | ||
738 | addr = hpc_list_ptr->phys_addr; | 741 | addr = hpc_list_ptr->phys_addr; |
739 | for (ctlr = 0; ctlr < hpc_list_ptr->num_ctlrs; ctlr++) { | 742 | for (ctlr = 0; ctlr < hpc_list_ptr->num_ctlrs; ctlr++) { |
@@ -897,12 +900,6 @@ static int __init ebda_rsrc_controller (void) | |||
897 | goto error_no_hp_info; | 900 | goto error_no_hp_info; |
898 | } | 901 | } |
899 | 902 | ||
900 | hp_slot_ptr->name = kmalloc(30, GFP_KERNEL); | ||
901 | if (!hp_slot_ptr->name) { | ||
902 | rc = -ENOMEM; | ||
903 | goto error_no_hp_name; | ||
904 | } | ||
905 | |||
906 | tmp_slot = kzalloc(sizeof(*tmp_slot), GFP_KERNEL); | 903 | tmp_slot = kzalloc(sizeof(*tmp_slot), GFP_KERNEL); |
907 | if (!tmp_slot) { | 904 | if (!tmp_slot) { |
908 | rc = -ENOMEM; | 905 | rc = -ENOMEM; |
@@ -964,9 +961,9 @@ static int __init ebda_rsrc_controller (void) | |||
964 | } /* each hpc */ | 961 | } /* each hpc */ |
965 | 962 | ||
966 | list_for_each_entry(tmp_slot, &ibmphp_slot_head, ibm_slot_list) { | 963 | list_for_each_entry(tmp_slot, &ibmphp_slot_head, ibm_slot_list) { |
967 | snprintf (tmp_slot->hotplug_slot->name, 30, "%s", create_file_name (tmp_slot)); | 964 | snprintf(name, SLOT_NAME_SIZE, "%s", create_file_name(tmp_slot)); |
968 | pci_hp_register(tmp_slot->hotplug_slot, | 965 | pci_hp_register(tmp_slot->hotplug_slot, |
969 | pci_find_bus(0, tmp_slot->bus), tmp_slot->device); | 966 | pci_find_bus(0, tmp_slot->bus), tmp_slot->device, name); |
970 | } | 967 | } |
971 | 968 | ||
972 | print_ebda_hpc (); | 969 | print_ebda_hpc (); |
@@ -976,8 +973,6 @@ static int __init ebda_rsrc_controller (void) | |||
976 | error: | 973 | error: |
977 | kfree (hp_slot_ptr->private); | 974 | kfree (hp_slot_ptr->private); |
978 | error_no_slot: | 975 | error_no_slot: |
979 | kfree (hp_slot_ptr->name); | ||
980 | error_no_hp_name: | ||
981 | kfree (hp_slot_ptr->info); | 976 | kfree (hp_slot_ptr->info); |
982 | error_no_hp_info: | 977 | error_no_hp_info: |
983 | kfree (hp_slot_ptr); | 978 | kfree (hp_slot_ptr); |