Lines Matching refs:lcla_pool
590 struct d40_lcla_pool lcla_pool; member
708 spin_lock_irqsave(&d40c->base->lcla_pool.lock, flags); in d40_lcla_alloc_one()
717 if (!d40c->base->lcla_pool.alloc_map[idx]) { in d40_lcla_alloc_one()
718 d40c->base->lcla_pool.alloc_map[idx] = d40d; in d40_lcla_alloc_one()
725 spin_unlock_irqrestore(&d40c->base->lcla_pool.lock, flags); in d40_lcla_alloc_one()
740 spin_lock_irqsave(&d40c->base->lcla_pool.lock, flags); in d40_lcla_free_all()
745 if (d40c->base->lcla_pool.alloc_map[idx] == d40d) { in d40_lcla_free_all()
746 d40c->base->lcla_pool.alloc_map[idx] = NULL; in d40_lcla_free_all()
755 spin_unlock_irqrestore(&d40c->base->lcla_pool.lock, flags); in d40_lcla_free_all()
830 struct d40_lcla_pool *pool = &chan->base->lcla_pool; in d40_log_lli_to_lcxa()
3271 base->lcla_pool.alloc_map = kcalloc(num_phy_chans in d40_hw_detect_init()
3273 sizeof(*base->lcla_pool.alloc_map), in d40_hw_detect_init()
3275 if (!base->lcla_pool.alloc_map) in d40_hw_detect_init()
3295 kfree(base->lcla_pool.alloc_map); in d40_hw_detect_init()
3375 struct d40_lcla_pool *pool = &base->lcla_pool; in d40_lcla_allocate()
3392 base->lcla_pool.pages = SZ_1K * base->num_phy_chans / PAGE_SIZE; in d40_lcla_allocate()
3396 base->lcla_pool.pages); in d40_lcla_allocate()
3400 base->lcla_pool.pages); in d40_lcla_allocate()
3404 free_pages(page_list[j], base->lcla_pool.pages); in d40_lcla_allocate()
3414 free_pages(page_list[j], base->lcla_pool.pages); in d40_lcla_allocate()
3417 base->lcla_pool.base = (void *)page_list[i]; in d40_lcla_allocate()
3425 __func__, base->lcla_pool.pages); in d40_lcla_allocate()
3426 base->lcla_pool.base_unaligned = kmalloc(SZ_1K * in d40_lcla_allocate()
3430 if (!base->lcla_pool.base_unaligned) { in d40_lcla_allocate()
3435 base->lcla_pool.base = PTR_ALIGN(base->lcla_pool.base_unaligned, in d40_lcla_allocate()
3448 writel(virt_to_phys(base->lcla_pool.base), in d40_lcla_allocate()
3582 base->lcla_pool.base = ioremap(res->start, in d40_probe()
3584 if (!base->lcla_pool.base) { in d40_probe()
3599 spin_lock_init(&base->lcla_pool.lock); in d40_probe()
3665 if (base->lcla_pool.base && base->plat_data->use_esram_lcla) { in d40_probe()
3666 iounmap(base->lcla_pool.base); in d40_probe()
3667 base->lcla_pool.base = NULL; in d40_probe()
3670 if (base->lcla_pool.dma_addr) in d40_probe()
3671 dma_unmap_single(base->dev, base->lcla_pool.dma_addr, in d40_probe()
3675 if (!base->lcla_pool.base_unaligned && base->lcla_pool.base) in d40_probe()
3676 free_pages((unsigned long)base->lcla_pool.base, in d40_probe()
3677 base->lcla_pool.pages); in d40_probe()
3679 kfree(base->lcla_pool.base_unaligned); in d40_probe()
3697 kfree(base->lcla_pool.alloc_map); in d40_probe()