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 mc_bus_dev = to_fsl_mc_device(mc_dev->dev.parent); 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()
141 dev_name(&mc_dev->dev)); in fsl_mc_resource_pool_remove_device()
150 mc_dev->resource = NULL; in fsl_mc_resource_pool_remove_device()
187 struct fsl_mc_device *mc_bus_dev = &mc_bus->mc_dev; in fsl_mc_resource_allocate()
274 int __must_check fsl_mc_object_allocate(struct fsl_mc_device *mc_dev, in fsl_mc_object_allocate() argument
285 if (mc_dev->flags & FSL_MC_IS_DPRC) in fsl_mc_object_allocate()
288 if (!dev_is_fsl_mc(mc_dev->dev.parent)) in fsl_mc_object_allocate()
294 mc_bus_dev = to_fsl_mc_device(mc_dev->dev.parent); in fsl_mc_object_allocate()
306 mc_adev->consumer_link = device_link_add(&mc_dev->dev, in fsl_mc_object_allocate()
443 int __must_check fsl_mc_allocate_irqs(struct fsl_mc_device *mc_dev) in fsl_mc_allocate_irqs() argument
453 if (mc_dev->irqs) in fsl_mc_allocate_irqs()
456 irq_count = mc_dev->obj_desc.irq_count; in fsl_mc_allocate_irqs()
460 if (is_fsl_mc_bus_dprc(mc_dev)) in fsl_mc_allocate_irqs()
461 mc_bus = to_fsl_mc_bus(mc_dev); in fsl_mc_allocate_irqs()
463 mc_bus = to_fsl_mc_bus(to_fsl_mc_device(mc_dev->dev.parent)); in fsl_mc_allocate_irqs()
470 dev_err(&mc_dev->dev, in fsl_mc_allocate_irqs()
475 irqs = devm_kcalloc(&mc_dev->dev, irq_count, sizeof(irqs[0]), in fsl_mc_allocate_irqs()
491 irqs[i]->mc_dev = mc_dev; in fsl_mc_allocate_irqs()
495 mc_dev->irqs = irqs; in fsl_mc_allocate_irqs()
500 irqs[i]->mc_dev = NULL; in fsl_mc_allocate_irqs()
511 void fsl_mc_free_irqs(struct fsl_mc_device *mc_dev) in fsl_mc_free_irqs() argument
516 struct fsl_mc_device_irq **irqs = mc_dev->irqs; in fsl_mc_free_irqs()
521 irq_count = mc_dev->obj_desc.irq_count; in fsl_mc_free_irqs()
523 if (is_fsl_mc_bus_dprc(mc_dev)) in fsl_mc_free_irqs()
524 mc_bus = to_fsl_mc_bus(mc_dev); in fsl_mc_free_irqs()
526 mc_bus = to_fsl_mc_bus(to_fsl_mc_device(mc_dev->dev.parent)); in fsl_mc_free_irqs()
532 irqs[i]->mc_dev = NULL; in fsl_mc_free_irqs()
536 mc_dev->irqs = NULL; in fsl_mc_free_irqs()
583 static int fsl_mc_allocator_probe(struct fsl_mc_device *mc_dev) in fsl_mc_allocator_probe() argument
590 if (!fsl_mc_is_allocatable(mc_dev)) in fsl_mc_allocator_probe()
593 mc_bus_dev = to_fsl_mc_device(mc_dev->dev.parent); in fsl_mc_allocator_probe()
598 error = object_type_to_pool_type(mc_dev->obj_desc.type, &pool_type); in fsl_mc_allocator_probe()
602 error = fsl_mc_resource_pool_add_device(mc_bus, pool_type, mc_dev); in fsl_mc_allocator_probe()
606 dev_dbg(&mc_dev->dev, in fsl_mc_allocator_probe()
615 static void fsl_mc_allocator_remove(struct fsl_mc_device *mc_dev) in fsl_mc_allocator_remove() argument
619 if (mc_dev->resource) { in fsl_mc_allocator_remove()
620 error = fsl_mc_resource_pool_remove_device(mc_dev); in fsl_mc_allocator_remove()
625 dev_dbg(&mc_dev->dev, in fsl_mc_allocator_remove()