1 1.19 thorpej /* $NetBSD: int_bus_dma.c,v 1.19 2023/12/20 13:55:17 thorpej Exp $ */ 2 1.1 rearnsha 3 1.10 thorpej /* 4 1.10 thorpej * Copyright (c) 2002 Wasabi Systems, Inc. 5 1.1 rearnsha * All rights reserved. 6 1.1 rearnsha * 7 1.10 thorpej * Written by Jason R. Thorpe for Wasabi Systems, Inc. 8 1.1 rearnsha * 9 1.1 rearnsha * Redistribution and use in source and binary forms, with or without 10 1.1 rearnsha * modification, are permitted provided that the following conditions 11 1.1 rearnsha * are met: 12 1.1 rearnsha * 1. Redistributions of source code must retain the above copyright 13 1.1 rearnsha * notice, this list of conditions and the following disclaimer. 14 1.1 rearnsha * 2. Redistributions in binary form must reproduce the above copyright 15 1.1 rearnsha * notice, this list of conditions and the following disclaimer in the 16 1.1 rearnsha * documentation and/or other materials provided with the distribution. 17 1.1 rearnsha * 3. All advertising materials mentioning features or use of this software 18 1.1 rearnsha * must display the following acknowledgement: 19 1.10 thorpej * This product includes software developed for the NetBSD Project by 20 1.10 thorpej * Wasabi Systems, Inc. 21 1.10 thorpej * 4. The name of Wasabi Systems, Inc. may not be used to endorse 22 1.10 thorpej * or promote products derived from this software without specific prior 23 1.10 thorpej * written permission. 24 1.1 rearnsha * 25 1.10 thorpej * THIS SOFTWARE IS PROVIDED BY WASABI SYSTEMS, INC. ``AS IS'' AND 26 1.10 thorpej * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED 27 1.1 rearnsha * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 28 1.10 thorpej * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL WASABI SYSTEMS, INC 29 1.1 rearnsha * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 30 1.1 rearnsha * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 31 1.1 rearnsha * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 32 1.1 rearnsha * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 33 1.1 rearnsha * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 34 1.1 rearnsha * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 35 1.1 rearnsha * POSSIBILITY OF SUCH DAMAGE. 36 1.1 rearnsha */ 37 1.10 thorpej 38 1.10 thorpej /* 39 1.10 thorpej * PCI DMA support for the ARM Integrator. 40 1.1 rearnsha */ 41 1.12 lukem 42 1.13 rearnsha #define _ARM32_BUS_DMA_PRIVATE 43 1.13 rearnsha 44 1.12 lukem #include <sys/cdefs.h> 45 1.19 thorpej __KERNEL_RCSID(0, "$NetBSD: int_bus_dma.c,v 1.19 2023/12/20 13:55:17 thorpej Exp $"); 46 1.1 rearnsha 47 1.1 rearnsha #include <sys/param.h> 48 1.1 rearnsha #include <sys/systm.h> 49 1.10 thorpej #include <sys/device.h> 50 1.1 rearnsha #include <sys/mbuf.h> 51 1.1 rearnsha 52 1.1 rearnsha #include <uvm/uvm_extern.h> 53 1.1 rearnsha 54 1.13 rearnsha #include <machine/bootconfig.h> 55 1.13 rearnsha 56 1.1 rearnsha #include <evbarm/integrator/int_bus_dma.h> 57 1.1 rearnsha 58 1.17 uebayasi #undef DEBUG 59 1.13 rearnsha #define DEBUG(x) 60 1.13 rearnsha 61 1.13 rearnsha static struct arm32_dma_range integrator_dma_ranges[DRAM_BLOCKS]; 62 1.13 rearnsha 63 1.13 rearnsha extern BootConfig bootconfig; 64 1.13 rearnsha 65 1.1 rearnsha void 66 1.10 thorpej integrator_pci_dma_init(bus_dma_tag_t dmat) 67 1.1 rearnsha { 68 1.10 thorpej struct arm32_dma_range *dr = integrator_dma_ranges; 69 1.13 rearnsha int i; 70 1.13 rearnsha int nranges = 0; 71 1.13 rearnsha 72 1.18 matt for (i = 0; i < bootconfig.dramblocks; i++) { 73 1.13 rearnsha if (bootconfig.dram[i].flags & BOOT_DRAM_CAN_DMA) { 74 1.13 rearnsha dr[nranges].dr_sysbase = bootconfig.dram[i].address; 75 1.13 rearnsha dr[nranges].dr_busbase = 76 1.13 rearnsha LOCAL_TO_CM_ALIAS(dr[nranges].dr_sysbase); 77 1.13 rearnsha dr[nranges].dr_len = bootconfig.dram[i].pages * NBPG; 78 1.13 rearnsha nranges++; 79 1.13 rearnsha } 80 1.18 matt } 81 1.1 rearnsha 82 1.13 rearnsha if (nranges == 0) 83 1.13 rearnsha panic ("integrator_pci_dma_init: No DMA capable memory"); 84 1.10 thorpej 85 1.10 thorpej dmat->_ranges = dr; 86 1.13 rearnsha dmat->_nranges = nranges; 87 1.10 thorpej 88 1.18 matt dmat->_dmamap_create = _bus_dmamap_create; 89 1.18 matt dmat->_dmamap_destroy = _bus_dmamap_destroy; 90 1.18 matt dmat->_dmamap_load = _bus_dmamap_load; 91 1.18 matt dmat->_dmamap_load_mbuf = _bus_dmamap_load_mbuf; 92 1.18 matt dmat->_dmamap_load_uio = _bus_dmamap_load_uio; 93 1.18 matt dmat->_dmamap_load_raw = _bus_dmamap_load_raw; 94 1.18 matt dmat->_dmamap_unload = _bus_dmamap_unload; 95 1.18 matt dmat->_dmamap_sync_pre = _bus_dmamap_sync; 96 1.18 matt dmat->_dmamap_sync_post = _bus_dmamap_sync; 97 1.10 thorpej 98 1.18 matt dmat->_dmamem_alloc = _bus_dmamem_alloc; 99 1.10 thorpej dmat->_dmamem_free = _bus_dmamem_free; 100 1.10 thorpej dmat->_dmamem_map = _bus_dmamem_map; 101 1.10 thorpej dmat->_dmamem_unmap = _bus_dmamem_unmap; 102 1.10 thorpej dmat->_dmamem_mmap = _bus_dmamem_mmap; 103 1.18 matt 104 1.18 matt dmat->_dmatag_subregion = _bus_dmatag_subregion; 105 1.18 matt dmat->_dmatag_destroy = _bus_dmatag_destroy; 106 1.1 rearnsha } 107