Lines Matching refs:res
32 struct resource *res = dev->resource + resno; in pci_std_update_resource() local
42 if (!res->flags) in pci_std_update_resource()
45 if (res->flags & IORESOURCE_UNSET) in pci_std_update_resource()
53 if (res->flags & IORESOURCE_PCI_FIXED) in pci_std_update_resource()
56 pcibios_resource_to_bus(dev->bus, ®ion, res); in pci_std_update_resource()
59 if (res->flags & IORESOURCE_IO) { in pci_std_update_resource()
61 new |= res->flags & ~PCI_BASE_ADDRESS_IO_MASK; in pci_std_update_resource()
66 new |= res->flags & ~PCI_BASE_ADDRESS_MEM_MASK; in pci_std_update_resource()
79 if (!(res->flags & IORESOURCE_ROM_ENABLE)) in pci_std_update_resource()
92 disable = (res->flags & IORESOURCE_MEM_64) && !dev->mmio_always_on; in pci_std_update_resource()
107 if (res->flags & IORESOURCE_MEM_64) { in pci_std_update_resource()
133 struct resource *res = &dev->resource[resource]; in pci_claim_resource() local
136 if (res->flags & IORESOURCE_UNSET) { in pci_claim_resource()
138 resource, res); in pci_claim_resource()
147 if (res->flags & IORESOURCE_ROM_SHADOW) in pci_claim_resource()
150 root = pci_find_parent_resource(dev, res); in pci_claim_resource()
153 resource, res); in pci_claim_resource()
154 res->flags |= IORESOURCE_UNSET; in pci_claim_resource()
158 conflict = request_resource_conflict(root, res); in pci_claim_resource()
161 resource, res, conflict->name, conflict); in pci_claim_resource()
162 res->flags |= IORESOURCE_UNSET; in pci_claim_resource()
195 static int pci_revert_fw_address(struct resource *res, struct pci_dev *dev, in pci_revert_fw_address() argument
205 start = res->start; in pci_revert_fw_address()
206 end = res->end; in pci_revert_fw_address()
207 res->start = fw_addr; in pci_revert_fw_address()
208 res->end = res->start + size - 1; in pci_revert_fw_address()
209 res->flags &= ~IORESOURCE_UNSET; in pci_revert_fw_address()
211 root = pci_find_parent_resource(dev, res); in pci_revert_fw_address()
224 if (res->flags & IORESOURCE_IO) in pci_revert_fw_address()
231 resno, res); in pci_revert_fw_address()
232 conflict = request_resource_conflict(root, res); in pci_revert_fw_address()
235 resno, res, conflict->name, conflict); in pci_revert_fw_address()
236 res->start = start; in pci_revert_fw_address()
237 res->end = end; in pci_revert_fw_address()
238 res->flags |= IORESOURCE_UNSET; in pci_revert_fw_address()
250 const struct resource *res, in pcibios_align_resource() argument
254 return res->start; in pcibios_align_resource()
260 struct resource *res = dev->resource + resno; in __pci_assign_resource() local
264 min = (res->flags & IORESOURCE_IO) ? PCIBIOS_MIN_IO : PCIBIOS_MIN_MEM; in __pci_assign_resource()
273 ret = pci_bus_alloc_resource(bus, res, size, align, min, in __pci_assign_resource()
283 if ((res->flags & (IORESOURCE_PREFETCH | IORESOURCE_MEM_64)) == in __pci_assign_resource()
285 ret = pci_bus_alloc_resource(bus, res, size, align, min, in __pci_assign_resource()
298 if (res->flags & (IORESOURCE_PREFETCH | IORESOURCE_MEM_64)) in __pci_assign_resource()
299 ret = pci_bus_alloc_resource(bus, res, size, align, min, 0, in __pci_assign_resource()
323 struct resource *res = dev->resource + resno; in pci_assign_resource() local
327 if (res->flags & IORESOURCE_PCI_FIXED) in pci_assign_resource()
330 res->flags |= IORESOURCE_UNSET; in pci_assign_resource()
331 align = pci_resource_alignment(dev, res); in pci_assign_resource()
334 resno, res); in pci_assign_resource()
338 size = resource_size(res); in pci_assign_resource()
347 pci_info(dev, "BAR %d: no space for %pR\n", resno, res); in pci_assign_resource()
348 ret = pci_revert_fw_address(res, dev, resno, size); in pci_assign_resource()
352 pci_info(dev, "BAR %d: failed to assign %pR\n", resno, res); in pci_assign_resource()
356 res->flags &= ~IORESOURCE_UNSET; in pci_assign_resource()
357 res->flags &= ~IORESOURCE_STARTALIGN; in pci_assign_resource()
358 pci_info(dev, "BAR %d: assigned %pR\n", resno, res); in pci_assign_resource()
369 struct resource *res = dev->resource + resno; in pci_reassign_resource() local
374 if (res->flags & IORESOURCE_PCI_FIXED) in pci_reassign_resource()
377 flags = res->flags; in pci_reassign_resource()
378 res->flags |= IORESOURCE_UNSET; in pci_reassign_resource()
379 if (!res->parent) { in pci_reassign_resource()
381 resno, res); in pci_reassign_resource()
386 new_size = resource_size(res) + addsize; in pci_reassign_resource()
389 res->flags = flags; in pci_reassign_resource()
391 resno, res, (unsigned long long) addsize); in pci_reassign_resource()
395 res->flags &= ~IORESOURCE_UNSET; in pci_reassign_resource()
396 res->flags &= ~IORESOURCE_STARTALIGN; in pci_reassign_resource()
398 resno, res, (unsigned long long) addsize); in pci_reassign_resource()
407 struct resource *res = dev->resource + resno; in pci_release_resource() local
409 pci_info(dev, "BAR %d: releasing %pR\n", resno, res); in pci_release_resource()
411 if (!res->parent) in pci_release_resource()
414 release_resource(res); in pci_release_resource()
415 res->end = resource_size(res) - 1; in pci_release_resource()
416 res->start = 0; in pci_release_resource()
417 res->flags |= IORESOURCE_UNSET; in pci_release_resource()
423 struct resource *res = dev->resource + resno; in pci_resize_resource() local
435 if (!(res->flags & IORESOURCE_UNSET)) in pci_resize_resource()
457 res->end = res->start + pci_rebar_size_to_bytes(size) - 1; in pci_resize_resource()
461 ret = pci_reassign_bridge_resources(dev->bus->self, res->flags); in pci_resize_resource()
469 res->end = res->start + pci_rebar_size_to_bytes(old) - 1; in pci_resize_resource()