if (!area || !(area->flags & VM_DMA_COHERENT)) return NULL;
WARN(area->flags != VM_DMA_COHERENT, "unexpected flags in area: %p\n", cpu_addr); return area->pages;
}
/* * Remaps an array of PAGE_SIZE pages into another vm_area. * Cannot be used in non-sleeping contexts
*/ void *dma_common_pages_remap(struct page **pages, size_t size,
pgprot_t prot, constvoid *caller)
{ void *vaddr;
/* * Remaps an allocated contiguous region into another vm_area. * Cannot be used in non-sleeping contexts
*/ void *dma_common_contiguous_remap(struct page *page, size_t size,
pgprot_t prot, constvoid *caller)
{ int count = PAGE_ALIGN(size) >> PAGE_SHIFT; struct page **pages; void *vaddr; int i;
pages = kvmalloc_array(count, sizeof(struct page *), GFP_KERNEL); if (!pages) return NULL; for (i = 0; i < count; i++)
pages[i] = nth_page(page, i);
vaddr = vmap(pages, count, VM_DMA_COHERENT, prot);
kvfree(pages);
return vaddr;
}
/* * Unmaps a range previously mapped by dma_common_*_remap
*/ void dma_common_free_remap(void *cpu_addr, size_t size)
{ struct vm_struct *area = find_vm_area(cpu_addr);
if (!area || !(area->flags & VM_DMA_COHERENT)) {
WARN(1, "trying to free invalid coherent area: %p\n", cpu_addr); return;
}
vunmap(cpu_addr);
}
Messung V0.5
¤ Dauer der Verarbeitung: 0.10 Sekunden
(vorverarbeitet)
¤
Die Informationen auf dieser Webseite wurden
nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit,
noch Qualität der bereit gestellten Informationen zugesichert.
Bemerkung:
Die farbliche Syntaxdarstellung und die Messung sind noch experimentell.