diff options
-rw-r--r-- | drivers/pci/hotplug/pciehp.h | 10 | ||||
-rw-r--r-- | drivers/pci/hotplug/pciehp_core.c | 90 |
2 files changed, 37 insertions, 63 deletions
diff --git a/drivers/pci/hotplug/pciehp.h b/drivers/pci/hotplug/pciehp.h index 4fb12fcda563..6a2f427768ca 100644 --- a/drivers/pci/hotplug/pciehp.h +++ b/drivers/pci/hotplug/pciehp.h | |||
@@ -50,7 +50,7 @@ extern int pciehp_force; | |||
50 | #define info(format, arg...) printk(KERN_INFO "%s: " format, MY_NAME , ## arg) | 50 | #define info(format, arg...) printk(KERN_INFO "%s: " format, MY_NAME , ## arg) |
51 | #define warn(format, arg...) printk(KERN_WARNING "%s: " format, MY_NAME , ## arg) | 51 | #define warn(format, arg...) printk(KERN_WARNING "%s: " format, MY_NAME , ## arg) |
52 | 52 | ||
53 | 53 | #define SLOT_NAME_SIZE 10 | |
54 | struct slot { | 54 | struct slot { |
55 | struct slot *next; | 55 | struct slot *next; |
56 | u8 bus; | 56 | u8 bus; |
@@ -63,6 +63,7 @@ struct slot { | |||
63 | struct hpc_ops *hpc_ops; | 63 | struct hpc_ops *hpc_ops; |
64 | struct hotplug_slot *hotplug_slot; | 64 | struct hotplug_slot *hotplug_slot; |
65 | struct list_head slot_list; | 65 | struct list_head slot_list; |
66 | char name[SLOT_NAME_SIZE]; | ||
66 | }; | 67 | }; |
67 | 68 | ||
68 | struct event_info { | 69 | struct event_info { |
@@ -233,13 +234,6 @@ static inline int wait_for_ctrl_irq(struct controller *ctrl) | |||
233 | return retval; | 234 | return retval; |
234 | } | 235 | } |
235 | 236 | ||
236 | #define SLOT_NAME_SIZE 10 | ||
237 | |||
238 | static inline void make_slot_name(char *buffer, int buffer_size, struct slot *slot) | ||
239 | { | ||
240 | snprintf(buffer, buffer_size, "%04d_%04d", slot->bus, slot->number); | ||
241 | } | ||
242 | |||
243 | enum php_ctlr_type { | 237 | enum php_ctlr_type { |
244 | PCI, | 238 | PCI, |
245 | ISA, | 239 | ISA, |
diff --git a/drivers/pci/hotplug/pciehp_core.c b/drivers/pci/hotplug/pciehp_core.c index f13f31323e85..051d228e634e 100644 --- a/drivers/pci/hotplug/pciehp_core.c +++ b/drivers/pci/hotplug/pciehp_core.c | |||
@@ -98,101 +98,81 @@ static void release_slot(struct hotplug_slot *hotplug_slot) | |||
98 | dbg("%s - physical_slot = %s\n", __FUNCTION__, hotplug_slot->name); | 98 | dbg("%s - physical_slot = %s\n", __FUNCTION__, hotplug_slot->name); |
99 | 99 | ||
100 | kfree(slot->hotplug_slot->info); | 100 | kfree(slot->hotplug_slot->info); |
101 | kfree(slot->hotplug_slot->name); | ||
102 | kfree(slot->hotplug_slot); | 101 | kfree(slot->hotplug_slot); |
103 | kfree(slot); | 102 | kfree(slot); |
104 | } | 103 | } |
105 | 104 | ||
105 | static void make_slot_name(struct slot *slot) | ||
106 | { | ||
107 | snprintf(slot->hotplug_slot->name, SLOT_NAME_SIZE, "%04d_%04d", | ||
108 | slot->bus, slot->number); | ||
109 | } | ||
110 | |||
106 | static int init_slots(struct controller *ctrl) | 111 | static int init_slots(struct controller *ctrl) |
107 | { | 112 | { |
108 | struct slot *slot; | 113 | struct slot *slot; |
109 | struct hpc_ops *hpc_ops; | ||
110 | struct hotplug_slot *hotplug_slot; | 114 | struct hotplug_slot *hotplug_slot; |
111 | struct hotplug_slot_info *hotplug_slot_info; | 115 | struct hotplug_slot_info *info; |
112 | u8 number_of_slots; | 116 | int retval = -ENOMEM; |
113 | u8 slot_device; | 117 | int i; |
114 | u32 slot_number; | ||
115 | int result = -ENOMEM; | ||
116 | 118 | ||
117 | number_of_slots = ctrl->num_slots; | 119 | for (i = 0; i < ctrl->num_slots; i++) { |
118 | slot_device = ctrl->slot_device_offset; | ||
119 | slot_number = ctrl->first_slot; | ||
120 | |||
121 | while (number_of_slots) { | ||
122 | slot = kzalloc(sizeof(*slot), GFP_KERNEL); | 120 | slot = kzalloc(sizeof(*slot), GFP_KERNEL); |
123 | if (!slot) | 121 | if (!slot) |
124 | goto error; | 122 | goto error; |
125 | 123 | ||
126 | slot->hotplug_slot = | 124 | hotplug_slot = kzalloc(sizeof(*hotplug_slot), GFP_KERNEL); |
127 | kzalloc(sizeof(*(slot->hotplug_slot)), | 125 | if (!hotplug_slot) |
128 | GFP_KERNEL); | ||
129 | if (!slot->hotplug_slot) | ||
130 | goto error_slot; | 126 | goto error_slot; |
131 | hotplug_slot = slot->hotplug_slot; | 127 | slot->hotplug_slot = hotplug_slot; |
132 | 128 | ||
133 | hotplug_slot->info = | 129 | info = kzalloc(sizeof(*info), GFP_KERNEL); |
134 | kzalloc(sizeof(*(hotplug_slot->info)), | 130 | if (!info) |
135 | GFP_KERNEL); | ||
136 | if (!hotplug_slot->info) | ||
137 | goto error_hpslot; | 131 | goto error_hpslot; |
138 | hotplug_slot_info = hotplug_slot->info; | 132 | hotplug_slot->info = info; |
139 | hotplug_slot->name = kmalloc(SLOT_NAME_SIZE, GFP_KERNEL); | ||
140 | if (!hotplug_slot->name) | ||
141 | goto error_info; | ||
142 | 133 | ||
143 | slot->ctrl = ctrl; | 134 | hotplug_slot->name = slot->name; |
144 | slot->bus = ctrl->slot_bus; | ||
145 | slot->device = slot_device; | ||
146 | slot->hpc_ops = hpc_ops = ctrl->hpc_ops; | ||
147 | 135 | ||
136 | slot->hp_slot = i; | ||
137 | slot->ctrl = ctrl; | ||
138 | slot->bus = ctrl->pci_dev->subordinate->number; | ||
139 | slot->device = ctrl->slot_device_offset + i; | ||
140 | slot->hpc_ops = ctrl->hpc_ops; | ||
148 | slot->number = ctrl->first_slot; | 141 | slot->number = ctrl->first_slot; |
149 | slot->hp_slot = slot_device - ctrl->slot_device_offset; | ||
150 | 142 | ||
151 | /* register this slot with the hotplug pci core */ | 143 | /* register this slot with the hotplug pci core */ |
152 | hotplug_slot->private = slot; | 144 | hotplug_slot->private = slot; |
153 | hotplug_slot->release = &release_slot; | 145 | hotplug_slot->release = &release_slot; |
154 | make_slot_name(hotplug_slot->name, SLOT_NAME_SIZE, slot); | 146 | make_slot_name(slot); |
155 | hotplug_slot->ops = &pciehp_hotplug_slot_ops; | 147 | hotplug_slot->ops = &pciehp_hotplug_slot_ops; |
156 | 148 | ||
157 | hpc_ops->get_power_status(slot, | 149 | get_power_status(hotplug_slot, &info->power_status); |
158 | &(hotplug_slot_info->power_status)); | 150 | get_attention_status(hotplug_slot, &info->attention_status); |
159 | hpc_ops->get_attention_status(slot, | 151 | get_latch_status(hotplug_slot, &info->latch_status); |
160 | &(hotplug_slot_info->attention_status)); | 152 | get_adapter_status(hotplug_slot, &info->adapter_status); |
161 | hpc_ops->get_latch_status(slot, | ||
162 | &(hotplug_slot_info->latch_status)); | ||
163 | hpc_ops->get_adapter_status(slot, | ||
164 | &(hotplug_slot_info->adapter_status)); | ||
165 | 153 | ||
166 | dbg("Registering bus=%x dev=%x hp_slot=%x sun=%x " | 154 | dbg("Registering bus=%x dev=%x hp_slot=%x sun=%x " |
167 | "slot_device_offset=%x\n", | 155 | "slot_device_offset=%x\n", slot->bus, slot->device, |
168 | slot->bus, slot->device, slot->hp_slot, slot->number, | 156 | slot->hp_slot, slot->number, ctrl->slot_device_offset); |
169 | ctrl->slot_device_offset); | 157 | retval = pci_hp_register(hotplug_slot); |
170 | result = pci_hp_register(hotplug_slot); | 158 | if (retval) { |
171 | if (result) { | 159 | err ("pci_hp_register failed with error %d\n", retval); |
172 | err ("pci_hp_register failed with error %d\n", result); | 160 | goto error_info; |
173 | goto error_name; | ||
174 | } | 161 | } |
175 | 162 | ||
176 | slot->next = ctrl->slot; | 163 | slot->next = ctrl->slot; |
177 | ctrl->slot = slot; | 164 | ctrl->slot = slot; |
178 | |||
179 | number_of_slots--; | ||
180 | slot_device++; | ||
181 | slot_number += ctrl->slot_num_inc; | ||
182 | } | 165 | } |
183 | 166 | ||
184 | return 0; | 167 | return 0; |
185 | |||
186 | error_name: | ||
187 | kfree(hotplug_slot->name); | ||
188 | error_info: | 168 | error_info: |
189 | kfree(hotplug_slot_info); | 169 | kfree(info); |
190 | error_hpslot: | 170 | error_hpslot: |
191 | kfree(hotplug_slot); | 171 | kfree(hotplug_slot); |
192 | error_slot: | 172 | error_slot: |
193 | kfree(slot); | 173 | kfree(slot); |
194 | error: | 174 | error: |
195 | return result; | 175 | return retval; |
196 | } | 176 | } |
197 | 177 | ||
198 | 178 | ||