cregit-Linux how code gets into the kernel

Release 4.16 arch/sh/kernel/dma-nommu.c

Directory: arch/sh/kernel
/*
 * DMA mapping support for platforms lacking IOMMUs.
 *
 * Copyright (C) 2009  Paul Mundt
 *
 * This file is subject to the terms and conditions of the GNU General Public
 * License.  See the file "COPYING" in the main directory of this archive
 * for more details.
 */
#include <linux/dma-mapping.h>
#include <linux/io.h>
#include <asm/cacheflush.h>


static dma_addr_t nommu_map_page(struct device *dev, struct page *page, unsigned long offset, size_t size, enum dma_data_direction dir, unsigned long attrs) { dma_addr_t addr = page_to_phys(page) + offset; WARN_ON(size == 0); if (!(attrs & DMA_ATTR_SKIP_CPU_SYNC)) sh_sync_dma_for_device(page_address(page) + offset, size, dir); return addr; }

Contributors

PersonTokensPropCommitsCommitProp
Paul Mundt6283.78%125.00%
Alexander Duyck912.16%125.00%
Krzysztof Kozlowski22.70%125.00%
Christoph Hellwig11.35%125.00%
Total74100.00%4100.00%


static int nommu_map_sg(struct device *dev, struct scatterlist *sg, int nents, enum dma_data_direction dir, unsigned long attrs) { struct scatterlist *s; int i; WARN_ON(nents == 0 || sg[0].length == 0); for_each_sg(sg, s, nents, i) { BUG_ON(!sg_page(s)); if (!(attrs & DMA_ATTR_SKIP_CPU_SYNC)) sh_sync_dma_for_device(sg_virt(s), s->length, dir); s->dma_address = sg_phys(s); s->dma_length = s->length; } return nents; }

Contributors

PersonTokensPropCommitsCommitProp
Paul Mundt10389.57%125.00%
Alexander Duyck97.83%125.00%
Krzysztof Kozlowski21.74%125.00%
Christoph Hellwig10.87%125.00%
Total115100.00%4100.00%

#ifdef CONFIG_DMA_NONCOHERENT
static void nommu_sync_single_for_device(struct device *dev, dma_addr_t addr, size_t size, enum dma_data_direction dir) { sh_sync_dma_for_device(phys_to_virt(addr), size, dir); }

Contributors

PersonTokensPropCommitsCommitProp
Paul Mundt3193.94%150.00%
Christoph Hellwig26.06%150.00%
Total33100.00%2100.00%


static void nommu_sync_sg_for_device(struct device *dev, struct scatterlist *sg, int nelems, enum dma_data_direction dir) { struct scatterlist *s; int i; for_each_sg(sg, s, nelems, i) sh_sync_dma_for_device(sg_virt(s), s->length, dir); }

Contributors

PersonTokensPropCommitsCommitProp
Paul Mundt5396.36%150.00%
Christoph Hellwig23.64%150.00%
Total55100.00%2100.00%

#endif const struct dma_map_ops nommu_dma_ops = { .alloc = dma_generic_alloc_coherent, .free = dma_generic_free_coherent, .map_page = nommu_map_page, .map_sg = nommu_map_sg, #ifdef CONFIG_DMA_NONCOHERENT .sync_single_for_device = nommu_sync_single_for_device, .sync_sg_for_device = nommu_sync_sg_for_device, #endif .is_phys = 1, };
void __init no_iommu_init(void) { if (dma_ops) return; dma_ops = &nommu_dma_ops; }

Contributors

PersonTokensPropCommitsCommitProp
Paul Mundt18100.00%1100.00%
Total18100.00%1100.00%


Overall Contributors

PersonTokensPropCommitsCommitProp
Paul Mundt32189.92%337.50%
Alexander Duyck185.04%112.50%
Christoph Hellwig113.08%112.50%
Krzysztof Kozlowski41.12%112.50%
Andrzej Pietrasiewicz20.56%112.50%
Bart Van Assche10.28%112.50%
Total357100.00%8100.00%
Directory: arch/sh/kernel
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.
Created with cregit.