- 追加された行はこの色です。
- 削除された行はこの色です。
*参照元 [#zb7d666b]
#backlinks
*説明 [#udb98bb4]
-パス: [[linux-4.4.1/include/linux/dma-mapping.h]]
-FIXME: これは何?
--説明
**参考 [#z67612a7]
-ざっくり検索した結果とそのリンク。
--[[linux-4.4.1/nommu_dma_ops(global)]]: arch/sh/kernel/dma-nommu.c
--[[linux-4.4.1/arm_dma_ops(global)]]: arch/arm/mm/dma-mapping.c
--[[linux-4.4.1/arm_coherent_dma_ops(global)]]: arch/arm/mm/dma-mapping.c
--[[linux-4.4.1/iommu_ops(global)]]: arch/arm/mm/dma-mapping.c
--[[linux-4.4.1/iommu_coherent_ops(global)]]: arch/arm/mm/dma-mapping.c
--[[linux-4.4.1/xen_swiotlb_dma_ops(global)]]: arch/arm/xen/mm.c
--[[linux-4.4.1/dmabounce_ops(global)]]: arch/arm/common/dmabounce.c
--[[linux-4.4.1/sta2x11_dma_ops(global)]]: arch/x86/pci/sta2x11-fixup.c
--[[linux-4.4.1/xen_swiotlb_dma_ops(global)]]: arch/x86/xen/pci-swiotlb-xen.c
--[[linux-4.4.1/calgary_dma_ops(global)]]: arch/x86/kernel/pci-calgary_64.c
--[[linux-4.4.1/gart_dma_ops(global)]]: arch/x86/kernel/amd_gart_64.c
--[[linux-4.4.1/nommu_dma_ops(global)]]: arch/x86/kernel/pci-nommu.c
--[[linux-4.4.1/swiotlb_dma_ops(global)]]: arch/x86/kernel/pci-swiotlb.c
--[[linux-4.4.1/sba_dma_ops(global)]]: arch/ia64/hp/common/sba_iommu.c
--[[linux-4.4.1/sn_dma_ops(global)]]: arch/ia64/sn/pci/pci_dma.c
--[[linux-4.4.1/swiotlb_dma_ops(global)]]: arch/ia64/kernel/pci-swiotlb.c
--[[linux-4.4.1/mips_default_dma_map_ops(global)]]: arch/mips/mm/dma-default.c
--[[linux-4.4.1/loongson_dma_map_ops(global)]]: arch/mips/loongson64/common/dma-swiotlb.c
--[[linux-4.4.1/nlm_swiotlb_dma_ops(global)]]: arch/mips/netlogic/common/nlm-dma.c
--[[linux-4.4.1/s390_dma_ops(global)]]: arch/s390/pci/pci_dma.c
--[[linux-4.4.1/tile_default_dma_map_ops(global)]]: arch/tile/kernel/pci-dma.c
--[[linux-4.4.1/tile_pci_default_dma_map_ops(global)]]: arch/tile/kernel/pci-dma.c
--[[linux-4.4.1/pci_swiotlb_dma_ops(global)]]: arch/tile/kernel/pci-dma.c
--[[linux-4.4.1/pci_hybrid_dma_ops(global)]]: arch/tile/kernel/pci-dma.c
--[[linux-4.4.1/alpha_pci_ops(global)]]: arch/alpha/kernel/pci_iommu.c
--[[linux-4.4.1/alpha_noop_ops(global)]]: arch/alpha/kernel/pci-noop.c
--[[linux-4.4.1/swiotlb_dma_ops(global)]]: arch/arm64/mm/dma-mapping.c
--[[linux-4.4.1/dummy_dma_ops(global)]]: arch/arm64/mm/dma-mapping.c
--[[linux-4.4.1/iommu_dma_ops(global)]]: arch/arm64/mm/dma-mapping.c
--[[linux-4.4.1/h8300_dma_map_ops(global)]]: arch/h8300/kernel/dma.c
--[[linux-4.4.1/sbus_dma_ops(global)]]: arch/sparc/kernel/ioport.c
--[[linux-4.4.1/pci32_dma_ops(global)]]: arch/sparc/kernel/ioport.c
--[[linux-4.4.1/sun4v_dma_ops(global)]]: arch/sparc/kernel/pci_sun4v.c
--[[linux-4.4.1/sun4u_dma_ops(global)]]: arch/sparc/kernel/iommu.c
--[[linux-4.4.1/swiotlb_dma_map_ops(global)]]: arch/unicore32/mm/dma-swiotlb.c
--[[linux-4.4.1/hexagon_dma_ops(global)]]: arch/hexagon/kernel/dma.c
--[[linux-4.4.1/or1k_dma_map_ops(global)]]: arch/openrisc/kernel/dma.c
--[[linux-4.4.1/xtensa_dma_map_ops(global)]]: arch/xtensa/kernel/pci-dma.c
--[[linux-4.4.1/dma_direct_ops(global)]]: arch/microblaze/kernel/dma.c
--[[linux-4.4.1/ps3_sb_dma_ops(global)]]: arch/powerpc/platforms/ps3/system-bus.c
--[[linux-4.4.1/ps3_ioc0_dma_ops(global)]]: arch/powerpc/platforms/ps3/system-bus.c
--[[linux-4.4.1/dma_iommu_fixed_ops(global)]]: arch/powerpc/platforms/cell/iommu.c
--[[linux-4.4.1/swiotlb_dma_ops(global)]]: arch/powerpc/kernel/dma-swiotlb.c
--[[linux-4.4.1/dma_direct_ops(global)]]: arch/powerpc/kernel/dma.c
--[[linux-4.4.1/vio_dma_mapping_ops(global)]]: arch/powerpc/kernel/vio.c
--[[linux-4.4.1/dma_iommu_ops(global)]]: arch/powerpc/kernel/dma-iommu.c
--[[linux-4.4.1/ibmebus_dma_ops(global)]]: arch/powerpc/kernel/ibmebus.c
--[[linux-4.4.1/__mic_dma_ops(global)]]: drivers/misc/mic/host/mic_boot.c
--[[linux-4.4.1/mic_dma_ops(global)]]: drivers/misc/mic/host/mic_boot.c
--[[linux-4.4.1/intel_dma_ops(global)]]: drivers/iommu/intel-iommu.c
--[[linux-4.4.1/amd_iommu_dma_ops(global)]]: drivers/iommu/amd_iommu.c
$ grep -r 'struct dma_map_ops [^*]' | grep '='
arch/sh/kernel/dma-nommu.c:struct dma_map_ops nommu_dma_ops = {
arch/arm/mm/dma-mapping.c:struct dma_map_ops arm_dma_ops = {
arch/arm/mm/dma-mapping.c:struct dma_map_ops arm_coherent_dma_ops = {
arch/arm/mm/dma-mapping.c:struct dma_map_ops iommu_ops = {
arch/arm/mm/dma-mapping.c:struct dma_map_ops iommu_coherent_ops = {
arch/arm/xen/mm.c:static struct dma_map_ops xen_swiotlb_dma_ops = {
arch/arm/common/dmabounce.c:static struct dma_map_ops dmabounce_ops = {
arch/x86/pci/sta2x11-fixup.c:static struct dma_map_ops sta2x11_dma_ops = {
arch/x86/xen/pci-swiotlb-xen.c:static struct dma_map_ops xen_swiotlb_dma_ops = {
arch/x86/kernel/pci-calgary_64.c:static struct dma_map_ops calgary_dma_ops = {
arch/x86/kernel/amd_gart_64.c:static struct dma_map_ops gart_dma_ops = {
arch/x86/kernel/pci-nommu.c:struct dma_map_ops nommu_dma_ops = {
arch/x86/kernel/pci-swiotlb.c:static struct dma_map_ops swiotlb_dma_ops = {
arch/ia64/hp/common/sba_iommu.c:struct dma_map_ops sba_dma_ops = {
arch/ia64/sn/pci/pci_dma.c:static struct dma_map_ops sn_dma_ops = {
arch/ia64/kernel/pci-swiotlb.c:struct dma_map_ops swiotlb_dma_ops = {
arch/mips/mm/dma-default.c:static struct dma_map_ops mips_default_dma_map_ops = {
arch/mips/loongson64/common/dma-swiotlb.c:static struct dma_map_ops loongson_dma_map_ops = {
arch/mips/netlogic/common/nlm-dma.c:struct dma_map_ops nlm_swiotlb_dma_ops = {
arch/s390/pci/pci_dma.c:struct dma_map_ops s390_dma_ops = {
arch/tile/kernel/pci-dma.c:static struct dma_map_ops tile_default_dma_map_ops = {
arch/tile/kernel/pci-dma.c:static struct dma_map_ops tile_pci_default_dma_map_ops = {
arch/tile/kernel/pci-dma.c:static struct dma_map_ops pci_swiotlb_dma_ops = {
arch/tile/kernel/pci-dma.c:static struct dma_map_ops pci_hybrid_dma_ops = {
arch/alpha/kernel/pci_iommu.c:struct dma_map_ops alpha_pci_ops = {
arch/alpha/kernel/pci-noop.c:struct dma_map_ops alpha_noop_ops = {
arch/arm64/mm/dma-mapping.c:static struct dma_map_ops swiotlb_dma_ops = {
arch/arm64/mm/dma-mapping.c:struct dma_map_ops dummy_dma_ops = {
arch/arm64/mm/dma-mapping.c:static struct dma_map_ops iommu_dma_ops = {
arch/h8300/kernel/dma.c:struct dma_map_ops h8300_dma_map_ops = {
arch/sparc/kernel/ioport.c:static struct dma_map_ops sbus_dma_ops = {
arch/sparc/kernel/ioport.c:struct dma_map_ops pci32_dma_ops = {
arch/sparc/kernel/pci_sun4v.c:static struct dma_map_ops sun4v_dma_ops = {
arch/sparc/kernel/iommu.c:static struct dma_map_ops sun4u_dma_ops = {
arch/unicore32/mm/dma-swiotlb.c:struct dma_map_ops swiotlb_dma_map_ops = {
arch/hexagon/kernel/dma.c:struct dma_map_ops hexagon_dma_ops = {
arch/openrisc/kernel/dma.c:struct dma_map_ops or1k_dma_map_ops = {
arch/xtensa/kernel/pci-dma.c:struct dma_map_ops xtensa_dma_map_ops = {
arch/microblaze/kernel/dma.c:struct dma_map_ops dma_direct_ops = {
arch/powerpc/platforms/ps3/system-bus.c:static struct dma_map_ops ps3_sb_dma_ops = {
arch/powerpc/platforms/ps3/system-bus.c:static struct dma_map_ops ps3_ioc0_dma_ops = {
arch/powerpc/platforms/cell/iommu.c:struct dma_map_ops dma_iommu_fixed_ops = {
arch/powerpc/kernel/dma-swiotlb.c:struct dma_map_ops swiotlb_dma_ops = {
arch/powerpc/kernel/dma.c:struct dma_map_ops dma_direct_ops = {
arch/powerpc/kernel/vio.c:struct dma_map_ops vio_dma_mapping_ops = {
arch/powerpc/kernel/dma-iommu.c:struct dma_map_ops dma_iommu_ops = {
arch/powerpc/kernel/ibmebus.c:static struct dma_map_ops ibmebus_dma_ops = {
drivers/misc/mic/host/mic_boot.c:static struct dma_map_ops __mic_dma_ops = {
drivers/misc/mic/host/mic_boot.c:static struct dma_map_ops mic_dma_ops = {
drivers/iommu/intel-iommu.c:struct dma_map_ops intel_dma_ops = {
drivers/iommu/amd_iommu.c:static struct dma_map_ops amd_iommu_dma_ops = {
*実装 [#z39a6233]
/*
* A dma_addr_t can hold any valid DMA or bus address for the platform.
* It can be given to a device to use as a DMA source or target. A CPU cannot
* reference a dma_addr_t directly because there may be translation between
* its physical address space and the bus address space.
*/
struct dma_map_ops {
void* (*alloc)(struct device *dev, size_t size,
dma_addr_t *dma_handle, gfp_t gfp,
struct dma_attrs *attrs);
-
--[[linux-4.4.1/device]]
--[[linux-4.4.1/dma_addr_t]]
--[[linux-4.4.1/gfp_t]]
--[[linux-4.4.1/dma_attrs]]
void (*free)(struct device *dev, size_t size,
void *vaddr, dma_addr_t dma_handle,
struct dma_attrs *attrs);
int (*mmap)(struct device *, struct vm_area_struct *,
void *, dma_addr_t, size_t, struct dma_attrs *attrs);
-
--[[linux-4.4.1/vm_area_struct]]
int (*get_sgtable)(struct device *dev, struct sg_table *sgt, void *,
dma_addr_t, size_t, struct dma_attrs *attrs);
-
--[[linux-4.4.1/sg_table]]
dma_addr_t (*map_page)(struct device *dev, struct page *page,
unsigned long offset, size_t size,
enum dma_data_direction dir,
struct dma_attrs *attrs);
-
--[[linux-4.4.1/page]]
--[[linux-4.4.1/dma_data_direction]]
void (*unmap_page)(struct device *dev, dma_addr_t dma_handle,
size_t size, enum dma_data_direction dir,
struct dma_attrs *attrs);
/*
* map_sg returns 0 on error and a value > 0 on success.
* It should never return a value < 0.
*/
int (*map_sg)(struct device *dev, struct scatterlist *sg,
int nents, enum dma_data_direction dir,
struct dma_attrs *attrs);
-
--[[linux-4.4.1/scatterlist]]
void (*unmap_sg)(struct device *dev,
struct scatterlist *sg, int nents,
enum dma_data_direction dir,
struct dma_attrs *attrs);
void (*sync_single_for_cpu)(struct device *dev,
dma_addr_t dma_handle, size_t size,
enum dma_data_direction dir);
void (*sync_single_for_device)(struct device *dev,
dma_addr_t dma_handle, size_t size,
enum dma_data_direction dir);
void (*sync_sg_for_cpu)(struct device *dev,
struct scatterlist *sg, int nents,
enum dma_data_direction dir);
void (*sync_sg_for_device)(struct device *dev,
struct scatterlist *sg, int nents,
enum dma_data_direction dir);
int (*mapping_error)(struct device *dev, dma_addr_t dma_addr);
int (*dma_supported)(struct device *dev, u64 mask);
int (*set_dma_mask)(struct device *dev, u64 mask);
#ifdef ARCH_HAS_DMA_GET_REQUIRED_MASK
-
--[[linux-4.4.1/ARCH_HAS_DMA_GET_REQUIRED_MASK]]
u64 (*get_required_mask)(struct device *dev);
#endif
int is_phys;
};
*コメント [#r12500ed]