Lines Matching refs:mc_dev
15 static bool __must_check fsl_mc_is_allocatable(struct fsl_mc_device *mc_dev) in fsl_mc_is_allocatable() argument
17 return is_fsl_mc_bus_dpbp(mc_dev) || in fsl_mc_is_allocatable()
18 is_fsl_mc_bus_dpmcp(mc_dev) || in fsl_mc_is_allocatable()
19 is_fsl_mc_bus_dpcon(mc_dev); in fsl_mc_is_allocatable()
35 *mc_dev) in fsl_mc_resource_pool_add_device()
39 struct fsl_mc_device *mc_bus_dev = &mc_bus->mc_dev; in fsl_mc_resource_pool_add_device()
44 if (!fsl_mc_is_allocatable(mc_dev)) in fsl_mc_resource_pool_add_device()
46 if (mc_dev->resource) in fsl_mc_resource_pool_add_device()
73 resource->id = mc_dev->obj_desc.id; in fsl_mc_resource_pool_add_device()
74 resource->data = mc_dev; in fsl_mc_resource_pool_add_device()
78 mc_dev->resource = resource; in fsl_mc_resource_pool_add_device()
98 *mc_dev) in fsl_mc_resource_pool_remove_device()
106 if (!fsl_mc_is_allocatable(mc_dev)) in fsl_mc_resource_pool_remove_device()
109 resource = mc_dev->resource; in fsl_mc_resource_pool_remove_device()
110 if (!resource || resource->data != mc_dev) in fsl_mc_resource_pool_remove_device()
113 mc_bus_dev = to_fsl_mc_device(mc_dev->dev.parent); in fsl_mc_resource_pool_remove_device()
135 dev_name(&mc_dev->dev)); in fsl_mc_resource_pool_remove_device()
144 mc_dev->resource = NULL; in fsl_mc_resource_pool_remove_device()
181 struct fsl_mc_device *mc_bus_dev = &mc_bus->mc_dev; in fsl_mc_resource_allocate()
268 int __must_check fsl_mc_object_allocate(struct fsl_mc_device *mc_dev, in fsl_mc_object_allocate() argument
279 if (mc_dev->flags & FSL_MC_IS_DPRC) in fsl_mc_object_allocate()
282 if (!dev_is_fsl_mc(mc_dev->dev.parent)) in fsl_mc_object_allocate()
288 mc_bus_dev = to_fsl_mc_device(mc_dev->dev.parent); in fsl_mc_object_allocate()
347 struct fsl_mc_device *mc_bus_dev = &mc_bus->mc_dev; in fsl_mc_populate_irq_pool()
404 struct fsl_mc_device *mc_bus_dev = &mc_bus->mc_dev; in fsl_mc_cleanup_irq_pool()
428 int __must_check fsl_mc_allocate_irqs(struct fsl_mc_device *mc_dev) in fsl_mc_allocate_irqs() argument
438 if (mc_dev->irqs) in fsl_mc_allocate_irqs()
441 irq_count = mc_dev->obj_desc.irq_count; in fsl_mc_allocate_irqs()
445 if (is_fsl_mc_bus_dprc(mc_dev)) in fsl_mc_allocate_irqs()
446 mc_bus = to_fsl_mc_bus(mc_dev); in fsl_mc_allocate_irqs()
448 mc_bus = to_fsl_mc_bus(to_fsl_mc_device(mc_dev->dev.parent)); in fsl_mc_allocate_irqs()
455 dev_err(&mc_dev->dev, in fsl_mc_allocate_irqs()
460 irqs = devm_kcalloc(&mc_dev->dev, irq_count, sizeof(irqs[0]), in fsl_mc_allocate_irqs()
476 irqs[i]->mc_dev = mc_dev; in fsl_mc_allocate_irqs()
480 mc_dev->irqs = irqs; in fsl_mc_allocate_irqs()
485 irqs[i]->mc_dev = NULL; in fsl_mc_allocate_irqs()
496 void fsl_mc_free_irqs(struct fsl_mc_device *mc_dev) in fsl_mc_free_irqs() argument
501 struct fsl_mc_device_irq **irqs = mc_dev->irqs; in fsl_mc_free_irqs()
506 irq_count = mc_dev->obj_desc.irq_count; in fsl_mc_free_irqs()
508 if (is_fsl_mc_bus_dprc(mc_dev)) in fsl_mc_free_irqs()
509 mc_bus = to_fsl_mc_bus(mc_dev); in fsl_mc_free_irqs()
511 mc_bus = to_fsl_mc_bus(to_fsl_mc_device(mc_dev->dev.parent)); in fsl_mc_free_irqs()
517 irqs[i]->mc_dev = NULL; in fsl_mc_free_irqs()
521 mc_dev->irqs = NULL; in fsl_mc_free_irqs()
571 static int fsl_mc_allocator_probe(struct fsl_mc_device *mc_dev) in fsl_mc_allocator_probe() argument
578 if (!fsl_mc_is_allocatable(mc_dev)) in fsl_mc_allocator_probe()
581 mc_bus_dev = to_fsl_mc_device(mc_dev->dev.parent); in fsl_mc_allocator_probe()
586 error = object_type_to_pool_type(mc_dev->obj_desc.type, &pool_type); in fsl_mc_allocator_probe()
590 error = fsl_mc_resource_pool_add_device(mc_bus, pool_type, mc_dev); in fsl_mc_allocator_probe()
594 dev_dbg(&mc_dev->dev, in fsl_mc_allocator_probe()
603 static int fsl_mc_allocator_remove(struct fsl_mc_device *mc_dev) in fsl_mc_allocator_remove() argument
607 if (!fsl_mc_is_allocatable(mc_dev)) in fsl_mc_allocator_remove()
610 if (mc_dev->resource) { in fsl_mc_allocator_remove()
611 error = fsl_mc_resource_pool_remove_device(mc_dev); in fsl_mc_allocator_remove()
616 dev_dbg(&mc_dev->dev, in fsl_mc_allocator_remove()