Lines Matching full:slot

21 	struct pci_slot *slot = to_pci_slot(kobj);  in pci_slot_attr_show()  local
23 return attribute->show ? attribute->show(slot, buf) : -EIO; in pci_slot_attr_show()
29 struct pci_slot *slot = to_pci_slot(kobj); in pci_slot_attr_store() local
31 return attribute->store ? attribute->store(slot, buf, len) : -EIO; in pci_slot_attr_store()
39 static ssize_t address_read_file(struct pci_slot *slot, char *buf) in address_read_file() argument
41 if (slot->number == 0xff) in address_read_file()
43 pci_domain_nr(slot->bus), in address_read_file()
44 slot->bus->number); in address_read_file()
47 pci_domain_nr(slot->bus), in address_read_file()
48 slot->bus->number, in address_read_file()
49 slot->number); in address_read_file()
57 static ssize_t max_speed_read_file(struct pci_slot *slot, char *buf) in max_speed_read_file() argument
59 return bus_speed_read(slot->bus->max_bus_speed, buf); in max_speed_read_file()
62 static ssize_t cur_speed_read_file(struct pci_slot *slot, char *buf) in cur_speed_read_file() argument
64 return bus_speed_read(slot->bus->cur_bus_speed, buf); in cur_speed_read_file()
70 struct pci_slot *slot = to_pci_slot(kobj); in pci_slot_release() local
72 dev_dbg(&slot->bus->dev, "dev %02x, released physical slot %s\n", in pci_slot_release()
73 slot->number, pci_slot_name(slot)); in pci_slot_release()
76 list_for_each_entry(dev, &slot->bus->devices, bus_list) in pci_slot_release()
77 if (PCI_SLOT(dev->devfn) == slot->number) in pci_slot_release()
78 dev->slot = NULL; in pci_slot_release()
81 list_del(&slot->list); in pci_slot_release()
82 pci_bus_put(slot->bus); in pci_slot_release()
84 kfree(slot); in pci_slot_release()
146 static int rename_slot(struct pci_slot *slot, const char *name) in rename_slot() argument
151 if (strcmp(pci_slot_name(slot), name) == 0) in rename_slot()
158 result = kobject_rename(&slot->kobj, slot_name); in rename_slot()
166 struct pci_slot *slot; in pci_dev_assign_slot() local
169 list_for_each_entry(slot, &dev->bus->slots, list) in pci_dev_assign_slot()
170 if (PCI_SLOT(dev->devfn) == slot->number) in pci_dev_assign_slot()
171 dev->slot = slot; in pci_dev_assign_slot()
177 struct pci_slot *slot; in get_slot() local
180 list_for_each_entry(slot, &parent->slots, list) in get_slot()
181 if (slot->number == slot_nr) { in get_slot()
182 kobject_get(&slot->kobj); in get_slot()
183 return slot; in get_slot()
190 * pci_create_slot - create or increment refcount for physical PCI slot
208 * The first slot is assigned N
209 * The second slot is assigned N-1
210 * The third slot is assigned N-2
215 * a slot. There is one notable exception - pSeries (rpaphp), where the
217 * the slot. In this scenario, the caller may pass -1 for @slot_nr.
225 * the 'placeholder' slot will not be displayed.
232 struct pci_slot *slot; in pci_create_slot() local
242 * Hotplug drivers are allowed to rename an existing slot, in pci_create_slot()
245 slot = get_slot(parent, slot_nr); in pci_create_slot()
246 if (slot) { in pci_create_slot()
248 if ((err = slot->hotplug ? -EBUSY : 0) in pci_create_slot()
249 || (err = rename_slot(slot, name))) { in pci_create_slot()
250 kobject_put(&slot->kobj); in pci_create_slot()
251 slot = NULL; in pci_create_slot()
259 slot = kzalloc(sizeof(*slot), GFP_KERNEL); in pci_create_slot()
260 if (!slot) { in pci_create_slot()
265 slot->bus = pci_bus_get(parent); in pci_create_slot()
266 slot->number = slot_nr; in pci_create_slot()
268 slot->kobj.kset = pci_slots_kset; in pci_create_slot()
273 pci_bus_put(slot->bus); in pci_create_slot()
274 kfree(slot); in pci_create_slot()
278 INIT_LIST_HEAD(&slot->list); in pci_create_slot()
279 list_add(&slot->list, &parent->slots); in pci_create_slot()
281 err = kobject_init_and_add(&slot->kobj, &pci_slot_ktype, NULL, in pci_create_slot()
284 kobject_put(&slot->kobj); in pci_create_slot()
291 dev->slot = slot; in pci_create_slot()
294 dev_dbg(&parent->dev, "dev %02x, created physical slot %s\n", in pci_create_slot()
295 slot_nr, pci_slot_name(slot)); in pci_create_slot()
300 return slot; in pci_create_slot()
302 slot = ERR_PTR(err); in pci_create_slot()
308 * pci_destroy_slot - decrement refcount for physical PCI slot
309 * @slot: struct pci_slot to decrement
315 void pci_destroy_slot(struct pci_slot *slot) in pci_destroy_slot() argument
317 dev_dbg(&slot->bus->dev, "dev %02x, dec refcount to %d\n", in pci_destroy_slot()
318 slot->number, kref_read(&slot->kobj.kref) - 1); in pci_destroy_slot()
321 kobject_put(&slot->kobj); in pci_destroy_slot()
337 struct hotplug_slot *slot = pci_slot->hotplug; in pci_hp_create_module_link() local
341 if (!slot || !slot->ops) in pci_hp_create_module_link()
343 kobj = kset_find_obj(module_kset, slot->mod_name); in pci_hp_create_module_link()
377 pr_err("PCI: Slot initialization failure\n"); in pci_slot_init()